web

Bootstrap输入建议库 autosuggest.js

Posted by Codeboy on December 22, 2015

轻量级输入提示控件auto suggest.github地址:https://github.com/androiddevelop/autosuggest.js。首先看一下下面的例子:

autosuggest.js

适用于Bootstrap的Ajax输入建议控件(Demo)

bootcomplete.js的基础上大幅度改进,改动如下:

  1. 文本框是去焦点时自动隐藏输入提示组件
  2. 增加最大建议数目限制(maxNum)
  3. 增加键盘方向键选择
  4. 增加文本对齐选择(align)
  5. 增加回车触发函数(nextStep)
  6. 增加以分隔符分割的联想(split)
  7. 增加匹配高亮(highlight)
  8. 增加第一个item是否默认被选中操作(firstSelected)

依赖

基本使用

$('#input').autosuggest({url:'/search.php'});

json数据格式(必须)

[ 
  {
   "id" : someId, 
   "label" : "some label name"
  }
]

id可以是任意值 如果服务端返回数据非此种格式,请修改。

参数

url:

提交请求地址,可以是json文件,注意跨域问题

method(非必须):

请求方式(get, post),默认get

queryParamName(非必须):

传递当前输入框的值时的参数名称,默认 query,即如果是get方式并保持该值为默认值,则请求url为 xxx.com?query=input_value,如果设置此值为 search ,则url为 xxx.com?search=input_value

align(非必须):

对齐方式,默认左对齐,可选项 leftcenterright

wrapperClass(非必须):

包围输入框外层div的css样式,见下面结构介绍

自动补全菜单的css样式,如果需要自定义请提供,见下面结构介绍

minLength(非必须):

发起请求的最小长度,只有>= 此长度时才会出现建议框,默认最小长度为 2

maxNum(非必须):

最大建议数目,默认最多给出 10 个建议提示

firstSelected(非必须):

第一个是否默认被选中,默认false

highlight(非必须):

是否高亮显示匹配内容,默认 false

split(非必须):

分隔符,例如我们需要文本框中输入多个省份,使用逗号分开,那么我们可以设定 split, ,之后 autosuggest.js 会根据最后一个逗号后面的内容进行建议。 默认为 null ,即把文本框中所有输入视为一个文本进行建议.

open(非必须):

建议框由隐藏状态变为可见状态时的回调,默认null

close(非必须):

建议框由可见状态变为隐藏状态时的回调,默认null

nextStep(非必须):

选中建议词后,建议框消失,之后点击回车要执行的函数。

immediate(非必须)

是否鼠标选中后或者键盘选中回车后立刻执行nextStep操作,默认 false ,即选中后,所选项将会填充到输入框中,需要再次回车执行nextStep操作

extra(非必须):

除了queryParam之外的其他参数. 使用:

 "key1" : "value1",
 "key2" : "value2"

结构

初始结构

<input type="text" class="form-control" id="text" placeholder="默认操作" autocomplete="off"/>

autosuggest作用后的结构

<div class="as-wrapper">
    <input type="text" class="form-control" id="text" placeholder="默认操作" autocomplete="off"/>
    <div class="as-menu list-group" style="display: none;">
        <span href="#" class="list-group-item  as-align-left" data-id="1" data-label="beijing">beijing</span>
        <span href="#" class="list-group-item  as-align-left" data-id="2" data-label="shanghai">shanghai</span>
        <span href="#" class="list-group-item  as-align-left " data-id="3" data-label="hangzhou">hangzhou</span>
        <span href="#" class="list-group-item  as-align-left " data-id="4" data-label="guangzhou">guangzhou</span>
        <span href="#" class="list-group-item  as-align-left " data-id="5" data-label="zhengzhou">zhengzhou</span>
    </div>
</div>

例子

//简单示例
$("#test").autosuggest({
    url: 'city.json',
    queryParamName: 'search'
});

//复杂示例
$("#test").autosuggest({
    url: 'city.json',
    minLength: 1,
    maxNum: 3,
    align: 'center',
    queryParamName: 'search'
    method: 'post',
    highlight: true,
    extra: {
        "key1": "value1",
        "key2": "value2"
    },
    nextStep: function () {
        alert("test");
    },
    split: ' ',
    open: function(){
        console.log("start open");
    },
    close: function(){
        console.log("start close");
    }
});

有任何问题,欢迎发送邮件到app@codeboy.me交流。

如有任何知识产权、版权问题或理论错误,还请指正。

转载请注明原作者及以上信息。