博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基于Jquery UI的autocompelet改写,自动补全控件,增加下拉选项,动态设置样式,点击显示所有选项,并兼容ie6+...
阅读量:6511 次
发布时间:2019-06-24

本文共 3997 字,大约阅读时间需要 13 分钟。

Jquery UI的autocompelete改写

注意:实现功能,除了原版的自动补全内容外,增加一个点击显示所有选项,样式能动态设置。

加载数据的来源为后台数据库读取。

具体代码如下:

引用

从官方下载插件包地址

我这里只选择了Autocomplete这个,其他工具不用到可以不勾选,最后选好就可以下载了。

要求的是jquery版本比较高,我这里用的是1.11版本,官方下载的里面有演示demo,也附有jquery包。

引用的顺序如下,两个js顺序不能乱了。

主体内容引用官方的示例

这是一个分割点1

Autocomplete

这是一个分割点2

这是一个分割点3

这是一个分割点4

这是一个分割点5

这是一个分割点6

以上加入多个分割点是为了让控件能正常显示在有滚动条的页面,并能随着滚动条一起滚动。

easyUI的控件combobox就不能实现这样的效果,一直浮于最上层。

js部分代码:

var availableTags = [                    "ActionScript",                    "AppleScript",                    "Asp",                    "BASIC",                    "C",                    "C++",                    "Clojure",                    "COBOL",                    "ColdFusion",                    "Erlang",                    "Fortran",                    "Groovy",                    "Haskell",                    "Java",                    "JavaScript",                    "Lisp",                    "Perl",                    "PHP",                    "Python",                    "Ruby",                    "测是啊",                    "测试"                  ];//json格式数据:var availableTagsJSON = [    { label: "C# Language", value: "C#" },    { label: "C++ Language", value: "C++" },    { label: "Java Language", value: "Java" },    { label: "JavaScript Language", value: "JavaScript" },    { label: "ASP.NET", value: "ASP.NET" },    { label: "JSP", value: "JSP" },    { label: "PHP", value: "PHP" },    { label: "Python", value: "Python" },    { label: "Ruby", value: "Ruby" }];$( "#autocomplete" ).autocomplete({    autoFocus: true,    source: availableTags});//点击下拉图片可以实现显示所有选项内容$('#test_btn').on('click',function (){    if ( $("#autocomplete").autocomplete( "widget" ).is( ":visible" ) ) {         $("#autocomplete").autocomplete( "close" );         return;    }    $(this).blur();    $("#autocomplete").autocomplete('search','');    $("#autocomplete").focus();});

对应的css样式为:

.ui-autocomplete {        max-height: 100px;        overflow-y: auto;        /* 防止水平滚动条 */        overflow-x: hidden;      }      input,img{ vertical-align:middle}      /* IE 6 不支持 max-height       * 我们使用 height 代替,但是这会强制菜单总是显示为那个高度       */      * html .ui-autocomplete {        height: 100px;      }      .autoSpan{        position:relative;      }      .imgUI{        position:absolute;        left:112px;      }

其中图片<img id="test_btn" src="./img/suggest_btn.gif"/>这个是一个向下的箭头

赋予动态的onclick方法,让它可以触发autocomplete的下拉显示所有选项。

$("#autocomplete").autocomplete('search','');这段是为了让控件显示所有内容的

而其中的' ',我在使用的时候要加上一个空格,官方文档说是不用加的,但是要配合后台数据。
加上一个空格,在后台返回的json格式数据的时候,label里开头或者结尾加上一个空格,
就能实现对全部数据的检索。

前端的代码还可以补充动态显示样式,如下:

//封装的调用后台的方法,这里就不适合其他项目了var jsonstr = get('/QrySelectAction',{typeName:code});var obj = JSON.parse(jsonstr);//json内容大致为://[{"label": "博客园", "value": "cnblogs","id":"id"},//{"label": "白兰", "value": "白兰","id":"id"}]$('#'+code).autocomplete({        autoFocus: true,        source: obj,        select: function(e, ui) {        //选择后增加一个属性值来存第三个id        $(this).attr('data-id',ui.item.id);//为了获取到这个控件的id值多增加一个data-id属性        },        create: function( event, ui ) {        // event 是当前事件对象        // ui对象是空的,只是为了和其他事件的参数签名保持一致        $(this).val(obj[0].label);        var width = $(this).width();//获取当前控件的高度        if(width>127){           var rew = width-127+112;           $(this).parent().find('img').css('left',rew+'px');//设置下拉按钮的相对位置         }         }});

后台代码使用的查询数据库返回对应的json.toString,然后在前端用~JSON.parse(jsonstr);~

转换成json格式后,才能让autocomplete读取出来。

后台注意在拼写label的值的时候,多一个空格,这样前端选择的时候给点击显示全部内容使用。

suggest_btn.gif944717-20171124153540984-1325183266.gif

最后效果如下:

944717-20171124154449890-13596711.png

转载于:https://www.cnblogs.com/FWebApp/p/7890937.html

你可能感兴趣的文章