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

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

css

 .select4_box {
     border: 1px solid #5897fb;
     position: absolute;
     width: 250px;
     background: #fff;
     border-radius: 4px;
     -webkit-box-shadow: 0 4px 5px rgba(0, 0, 0, .15);
     box-shadow: 0 4px 5px rgba(0, 0, 0, .15);
     z-index: 9999;
 }

 .select4_box ul {
     padding: 0px;
     margin: 5px;
 }

 .select4_box ul li {
     list-style: none;
     padding: 3px 7px 4px;
     cursor: pointer;
 }

 .select4_box ul li:hover {
     background: #51A9A9;
     color: #fff;
 }

 .select4_box ul li.active {
     background: #3875d7;
     color: #fff;
 }

html

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

jQuery插件

 (function ($) {
     $.fn.extend({
         select4: function (options) {
             var defaults = {
                 ajax_url: true
             }
             var options = $.extend(defaults, options);

             return this.each(function () {
                 $(".h2").remove();
                 var mythis = $(this);

                 $(document).on("click", ".select4_box li", function () {
                     mythis.val($(this).text());
                     $(".select4_box").remove();
                 });

                 $(document).click(function (event) {
                     $(".select4_box").remove();
                 });

                 $(".select4_box").click(function (event) {
                     event.stopPropagation();
                 });

                 mythis.click(function (event) {
                     var val = $(this).val();
                     console.log(val);
                     var mythis = $(this);
                     var width = $(this).width() + 14 + "px";
                     var top = $(this).position().top + 30;
                     var left = $(this).position().left;
                     $.ajax({
                         url: options.ajax_url,
                         dataType: "json",
                         data: {name: val},
                         success: function (json) {
                             if (json.data) {
                                 var html = '<div class="select4_box"><ul>';
                                 $.each(json.data, function (k, v) {
                                     html += '<li alt="' + v.id + '">' + v.name + '</li>';
                                 });
                                 html += '</ul></div>'
                                 $(".select4_box").remove();
                                 mythis.after(html);
                                 $(".select4_box").css({top: top, left: left, width: width});
                             }
                         }
                     });
                 });

                 mythis.keyup(function (event) {
                     if (event.keyCode == 40) {
                         var index = $(".select4_box li.active").index() + 1;
                         $(".select4_box li").eq(index).addClass('active').siblings().removeClass('active');
                         mythis.val($(".select4_box li.active").text());
                     } else if (event.keyCode == 38) {
                         var index = $(".select4_box li.active").index() - 1;
                         if (index ) {
                             index = $(".select4_box li").length - 1;
                         }
                         $(".select4_box li").eq(index).addClass('active').siblings().removeClass('active');
                         mythis.val($(".select4_box li.active").text());
                     } else if (event.keyCode == 13) {
                         event.stopPropagation();
                         alert($(".select4_box li.active").text());
                         mythis.val($(".select4_box li.active").text());
                         return false;
                     } else {
                         mythis.trigger("click");
                     }
                 });

             });

         }
     });
 })(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)
}

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

  1. z-blog博客组插件openSug.js百度搜索下拉框提示代码

      z-blog安装openSug插件即可获得带有“搜索框提示”功能的搜索框,让z-blog搜索更便捷! https://www.opensug.org/.../opensug_z-blog_v1.0 ...

  2. Dropdown.js基于jQuery开发的轻量级下拉框插件

    Dropdown.js 前言 在SPA(Single Page Application)盛行的时代,jQuery插件的轮子正在减少,由于我厂有需求而开发了这个插件.如果觉得本文对您有帮助,请给个赞,以 ...

  3. Springboot+Vue实现仿百度搜索自动提示框匹配查询功能

    案例功能效果图 前端初始页面 输入搜索信息页面 点击查询结果页面 环境介绍 前端:vue 后端:springboot jdk:1.8及以上 数据库:mysql 核心代码介绍 TypeCtrler .j ...

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

    原始的下拉框不好看这里推荐一个jQuery自定义漂亮的下拉框插件8种效果演示 在线预览 下载地址 实例代码 <!DOCTYPE html> <html lang="en&q ...

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

    jquery选中将select下拉框中一项后赋值给text文本框,出现无法将第一个下拉框的value赋值给文本框 因为select默认选中第一项..在选择第一项时,便导致无法激发onchange事件. ...

  6. jquery+html三级联动下拉框

    jquery+html三级联动下拉框及详情页面加载时的select初始化问题   html写的三个下拉框,如下: <select name="ddlQYWZYJ" id=&q ...

  7. 基于jQuery select下拉框美化插件

    分享一款基于jQuery select下拉框美化插件.该插件适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗.效果图如下: 在线预览   源码下 ...

  8. ComboBox可搜索下拉框的使用注意事项,简单记录以及我遇到的一些奇怪的bug

    前几天做一个react的项目的时候需要用一个可搜索的下拉框ComboBox,上代码: <ComboBox // className={comboxClassName} items={storeA ...

  9. layui-table-column-select(layui数据表格可搜索下拉框select)

    layuiTableColumnSelect 在layui table的基础上对表格列进行扩展:点击单元格显示可搜索下拉列表. 码云地址:https://gitee.com/yangqianlong9 ...

随机推荐

  1. EOS单向N对1关联

    1. N端实体中用于关联的属性可以是主键也可以是非主键,1端的关联字段必须是主键(可以是单主键也可以是复合主键). 如下图关联字段:orgid 2.当在N端选择了用于关联的属性,那么这些属性在N端实体 ...

  2. Oracle 11g 下载|Oracle 11g 官网下载|Oracle 11g 官网下载 带登录用户和密码

    本文转载自 Oracle 11g 下载|Oracle 11g 官网下载|Oracle 11g 官网下载 带登录用户和密码 oracle 下载还需要用户名我自己注册了个方便大家使用下载直接点击提示找不到 ...

  3. Unity3d《Shader篇》漫反射

    Unity3d<Shader篇>漫反射 Shader "Custom/Ambient" { Properties { _MainTex ("Base (RGB ...

  4. Win7下打开计算机管理时出现错误的解决办法

    计算机管理是用户在使用计算机时经常用到的一个选项,可以在桌面上右击计算机,选择"管理"打开.也可以在运行框中输入:compmgmt.msc打开计算机管理程序,里面有常用系统工具如用 ...

  5. ABAP 内表的行列转换-发货通知单-打印到Excel里

    需要传入数据到Excel里的模板如上图所示 ********************** *           设计主要逻辑与原理说明                                 ...

  6. Android Volley入门到精通:初识Volley的基本用法

    1. Volley简介 我们平时在开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据.Android系统中主要提供了两种方式来进行H ...

  7. UVA 156 Ananagrams ---map

    题目链接 题意:输入一些单词,找出所有满足如下条件的单词:该单词不能通过字母重排,得到输入文本中的另外一个单词.在判断是否满足条件时,字母不分大小写,但在输出时应保留输入中的大小写,按字典序进行排列( ...

  8. 更新补丁Bind

    1.查询补丁版本信息 (1) rpm -qa|grep bind (2) dig @localhost version.bind 2.下载安装 BIND最新漏洞和升级解决办法 现在有非常多的公司的都有 ...

  9. 25个增强iOS应用程序性能的提示和技巧(初级篇)

    25个增强iOS应用程序性能的提示和技巧(初级篇) 标签: ios内存管理性能优化 2013-12-13 10:53 916人阅读 评论(0) 收藏 举报  分类: IPhone开发高级系列(34)  ...

  10. Centos7 ZooKeeper 安装过程

    www.apache.org/dist/上可以下载Hadoop整个生态环境的组件,我下的Zookeeper3.4.6版本 我一般都是在一个虚拟机上将一.二步都做完,然后克隆出来,再到克隆出来的虚拟机上 ...