jquery 仿百度搜索下拉框的插件

转载地址:http://www.open-open.com/lib/view/open1420624048437.html

今天写了个下拉插件分享出来 
效果: , 可以搜素,也可以使用上下键选择匹配出来的值

css

 1 .select4_box {
 2     border: 1px solid #5897fb;
 3     position: absolute;
 4     width: 250px;
 5     background: #fff;
 6     border-radius: 4px;
 7     -webkit-box-shadow: 0 4px 5px rgba(0, 0, 0, .15);
 8     box-shadow: 0 4px 5px rgba(0, 0, 0, .15);
 9     z-index: 9999;
10 }
11
12 .select4_box ul {
13     padding: 0px;
14     margin: 5px;
15 }
16
17 .select4_box ul li {
18     list-style: none;
19     padding: 3px 7px 4px;
20     cursor: pointer;
21 }
22
23 .select4_box ul li:hover {
24     background: #51A9A9;
25     color: #fff;
26 }
27
28 .select4_box ul li.active {
29     background: #3875d7;
30     color: #fff;
31 }

html

<input type="text"  name="Shoushuid"  class="Shoushuid"  autocomplete="off">
<input type="text"  name="Jiancha_xiangmu"  class="Jiancha_xiangmu"  autocomplete="off">

jQuery插件

 1 (function ($) {
 2     $.fn.extend({
 3         select4: function (options) {
 4             var defaults = {
 5                 ajax_url: true
 6             }
 7             var options = $.extend(defaults, options);
 8
 9             return this.each(function () {
10                 $(".h2").remove();
11                 var mythis = $(this);
12
13                 $(document).on("click", ".select4_box li", function () {
14                     mythis.val($(this).text());
15                     $(".select4_box").remove();
16                 });
17
18                 $(document).click(function (event) {
19                     $(".select4_box").remove();
20                 });
21
22                 $(".select4_box").click(function (event) {
23                     event.stopPropagation();
24                 });
25
26                 mythis.click(function (event) {
27                     var val = $(this).val();
28                     console.log(val);
29                     var mythis = $(this);
30                     var width = $(this).width() + 14 + "px";
31                     var top = $(this).position().top + 30;
32                     var left = $(this).position().left;
33                     $.ajax({
34                         url: options.ajax_url,
35                         dataType: "json",
36                         data: {name: val},
37                         success: function (json) {
38                             if (json.data) {
39                                 var html = ‘<div class="select4_box"><ul>‘;
40                                 $.each(json.data, function (k, v) {
41                                     html += ‘<li alt="‘ + v.id + ‘">‘ + v.name + ‘</li>‘;
42                                 });
43                                 html += ‘</ul></div>‘
44                                 $(".select4_box").remove();
45                                 mythis.after(html);
46                                 $(".select4_box").css({top: top, left: left, width: width});
47                             }
48                         }
49                     });
50                 });
51
52                 mythis.keyup(function (event) {
53                     if (event.keyCode == 40) {
54                         var index = $(".select4_box li.active").index() + 1;
55                         $(".select4_box li").eq(index).addClass(‘active‘).siblings().removeClass(‘active‘);
56                         mythis.val($(".select4_box li.active").text());
57                     } else if (event.keyCode == 38) {
58                         var index = $(".select4_box li.active").index() - 1;
59                         if (index < 0) {
60                             index = $(".select4_box li").length - 1;
61                         }
62                         $(".select4_box li").eq(index).addClass(‘active‘).siblings().removeClass(‘active‘);
63                         mythis.val($(".select4_box li.active").text());
64                     } else if (event.keyCode == 13) {
65                         event.stopPropagation();
66                         alert($(".select4_box li.active").text());
67                         mythis.val($(".select4_box li.active").text());
68                         return false;
69                     } else {
70                         mythis.trigger("click");
71                     }
72                 });
73
74             });
75
76
77         }
78     });
79 })(jQuery);

使用

<script>
$(function(){
    //ajax_url是这个input绑定的ajax数据地址
    $(".Jiancha_xiangmu").select4({"ajax_url":"/jiancha/select"});
    $(".Shoushuid").select4({"ajax_url":"/jiancha/select"});
});
</script>

这个ajax的数据必须是这种格式的,当然你也可以改,插件那里我写的应该都能看懂

ajax数据,我后台使用的是go语言,你也可以换成你熟悉的语言

func (this *JianchaController) Select() {
	var name = this.GetString("name")
	where := models.NewWhere()
	if name != "" {
		where["like__name"] = "%" + name + "%"
	}
	data, _ := models.M("jiancha").Where(where).Select()
	this.AjaxReturn(1, "ok", data)
}
时间: 2024-10-16 14:55:48

jquery 仿百度搜索下拉框的插件的相关文章

jQuery自动显示搜索下拉框

描述:当用选择查询时,根据输入的关键字动态从后台模糊查询,把结果异步显示在前端. jsp代码; <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> <% String

百度搜索下拉框提示代码 opensug.js

opensug ·简单方式--方便的将"百度搜索框(带提示功能)"直接加入到您的网页中. 将以下代码加入到您的网页中,即可获得带有"搜索框提示"功能的百度搜索框. HTML代码: <form action="http://www.baidu.com/baidu" target="_blank"> <table bgcolor="#FFFFFF"><tr><td>

搜索下拉框

学习的过程中总会遇到很多同类的问题,把这写常用的东西写出来供参考不错,今天开始做这件事.今天是实现的搜索下拉框,代码如下: 1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>搜索下拉框</title> 6 <script src="http://cdn.bootcss.com/jquery/2.1.4/jque

基于jQuery select下拉框美化插件

今天给大家分享一款基于jQuery select下拉框美化插件,这款插件适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗.  <table>         <tr>             <td>                 <h2>                     演示1</h2>                 <select name="drop1&qu

jQuery自定义漂亮的下拉框插件8种效果演示

原始的下拉框不好看这里推荐一个jQuery自定义漂亮的下拉框插件8种效果演示 在线预览 下载地址 实例代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 <!DOCTYPE html> <html lang="en" class=

jquery选中将select下拉框中一项后赋值给text文本框

jquery选中将select下拉框中一项后赋值给text文本框,出现无法将第一个下拉框的value赋值给文本框 因为select默认选中第一项..在选择第一项时,便导致无法激发onchange事件.所以无法进行赋值给文本框 解决方法. select下拉框设置第一项做一个无用的占位option <script type="text/javascript">     function changeSelect(obj) {         var _this = obj;  

自制jquery可编辑的下拉框

昨天看到QQ登录的时候,可以选择以前登录过的账户,这个东西也可以在网站登录的时候用到,所以我就想做一个这样的插件:在网上查了很多,没有找到合适自己的,所以决定自动制作一个. 原理就是一个textbox加一个ul模拟下拉框,用font模拟一个下拉按钮. 一.制作静态效果 先用css和html,做出一个应该有的样子.这里这两个我使用的是字体,可以在icomoon网站上面自己制作.用字体的好处是和输入框定位很方便,而且还可以控制大小颜色等,唯一的不足是IE6和IE7由于不支持:before选择器,导致

2019如何刷百度电脑下拉框?

如何刷百度下拉框? 巧推网业务主要是快速排名和下拉框排名,今天小编给大家说说百度下拉框排名是怎么刷,以及效果如何?下面先看看我们给自己刷的几个案例: 以上是2个百度电脑端下拉框案例,我们可以看到其构成是“主关键词”+后缀副词:比如“企业排名优化”是主词,“巧推网”就是后缀词,我们在刷词的时候,后缀一般都是我们的品牌词.这样用户点击这个下拉词的时候,就会匹配到我们官网信息,从而起到引流的作用. 不仅如此,即时用户没有点击进来,也起到了增加我们品牌词曝光率. 刷下拉词的大概原理就是系统模仿用户的搜索

jQuery动态生成&lt;select&gt;下拉框

前一阵在项目里需要动态生成下拉框,找了一下用jQuery实现比较方便,这里整理一下. 下文所述方法只是本人在项目中遇到问题的解决方法,场景较为简单,也希望能帮助有需要的朋友 1.动态生成下拉框的两种方式 (1)将数据放在model中,JSP页面用EL表达式${}取出,该方式缺点是数据更改时必须刷新整个页面,本文不过多描述. (2)就是本文要说的jQuery动态生成了,该方式适合数据频繁变动的场景. 2.<select>组成 <select> <option value=”aa