之前使用过此 widget,如今再次需要,发现很多东西已经记不起来了,当然之前用的版本也不一样。

使用之前当然是先认真阅读官方的说明文档和示例,这点很重要,而不是东一块西一点的去网上瞎找资料。Options,Methods,Events 区分的很详细,参考 jQuery Autocomplete Widget API DOC 。

我需要的场景是,一个文本框,根据动态输入,ajax get data source,select 结果后做些 dom 操作。这是一个简单场景,当然我需要的其实很复杂,后面讲。先说我遇到的问题。

先看使用代码:

function registerAuto() {
var autoId = "cust-code";
$("#" + autoId)
.autocomplete({
source: function(request, response) {
var term = $.trim(request.term);
//term.replace("$", "") only replace the first match one
if (term.length === 0 || $.trim(term.split("$").join("")).length === 0) {
return;
}
$.ajax({
url: "/order/aeo/customer",
method: "post",
dataType: "json",
data: { keywords: term },
success: function(data) {
response(data);
}
});
},
delay: 800,
autoFocus: true,
minLength: 2,
position: { my: "left bottom", at: "left top" },
select: function(event, ui) {
//console.log(ui);
showCustomer(ui.item.value);
},
change: function(event, ui) {
//console.log(ui);
if (!ui.item) {
$("#" + autoId).val("");
hideCustomer();
}
}
});
}

  

问题一:

有一个初始值,当页面加载后,赋值文本框,自动执行搜索,然后选取记录(single item 只有一条结果记录)。为什么这样做,是因为需要触发 select 事件。

该怎么办呢?

解决方案:

1、最简单的办法就是:赋值文本框,然后手动调用 select 里面需要执行的方法,不需要执行 autocomplete。

 $(function() {
registerAuto();
$("#cust-code").val("@Model.CustomerCode");
showCustomer("@Model.CustomerCode");
});

如上代码就行了,但是本人很倔,就是要 autocomplete 方式,手动的去调用它的方法去触发事件。

2、开始以为,只要 focus 文本框,然后赋值文本就会触发自动搜索事件,结果是根本不行的。

辛苦搜索了很多资料,以 jquery autocomplete manually search 关键信息才找到解决方法。

 $(function() {
registerAuto();
$("#cust-code").val("@Model.CustomerCode");
$("#cust-code").autocomplete("search");
});

代码触发 search 事件,但问题又来,怎么实现自动 select 结果呢?使用的是投机的方式,根据生成的 items ui 去 click 标签。

 $(function() {
registerAuto();
$("#cust-code").val("@Model.CustomerCode");
$("#cust-code").autocomplete("search");
setTimeout(function() {
$(".ui-menu-item").click();
}, 100);
});

其中的 setTimeout,是为了有足够的时间等待 ajax 返回结果。

好了上面问题是解决了,但一个终极问题,应该也是很多人遇到的问题,却需要亟待解决。

问题二:

ajax 返回结果太多,如何动态分页的去获取结果,而不是一次性加载呢?

解决思路:

自己想到了一个方案:搜索结果有滚动条,当滚动条到底部时,自动加载下一页结果,直到全部加载完。其实,用户可能只加载几页,找不到结果就换关键词重新搜索了。

但遇到的难题是:怎么把动态加载的结果,append 到 autocomplete 的 data source 里面,因为其他事件(如 select )需要。

又想到的解决是:修改 autocomplete 源码,增加扩展方法;或者绑定事件到 items ui 上,如 scroll bar 加载方法,click select 方法等。

解决方案:

总之目前没有实现,不知道诸君有何建议?

2016-11-25

最近的使用,又有一些新的需求,然后又找到了一些解决方案,总之是越用越顺手了。

问题三:

autocomplete 默认接受的对象是这样的 { label : "label", value : "value" } ,但使用时需要显示更多的 label 数据,以及需要获取除 value 之外的其他数据,怎么办呢?

简单的解决办法:

lablel 拼接数据显示,但不能用 html 做丰富显示,因为都当作字符串。

value 也以一定规则拼接,但是最后 value 要展示在 input 中,看起来很不友好。

终极解决方案:

使用 _renderItem 扩展解决 label 问题,自定义显示内容;

由于 autocomplete 是将 source 保存起来的,因此 response(data) 的时候去了 label 和 value 外,可以自定义其他属性,或者 label 使用一个对象。

 $(".auto-stock")
.autocomplete({
source: function(request, response) {
var term = $.trim(request.term);
if (term.length === 0) {
return;
}
$.getJSON("/api/query",
{ keyword: term },
function(data) {
//data 类型假设是 { id, code, name, type }
response($.map(data,
function() {
return { label: data, value: data.name };
//或者
//return { label: name, value: data.name, code : data.code, id : data.id };
}));
});
},
delay: 100,
autoFocus: true,
minLength: 2,
position: { my: "left top", at: "left buttom" },
select: function(event, ui) {
//console.log(ui.item);
//这里可以获得自定义 label 对象,或者其他属性
setQuery(ui.item.label);
},
change: function(event, ui) {
//console.log(ui);
if (!ui.item) {
$(this).val("");
}
}
})
.data("ui-autocomplete")
._renderItem = function(ul, item) {
return $("<li>")
.attr("data-value", item.value)
//自定义显示 ui
.append("<div><dd>" + item.label.code + "</dd><dd>" + item.label.name + "</dd><dd>" + item.label.type + "</dd></div>")
.appendTo(ul);
}

对 autocomplete 的使用又多了一些心得,其他下次有需要时,解决掉 pagination 的问题。

jQuery Autocomplete 备忘录的更多相关文章

  1. jQuery AutoComplete 自动补全

    jQuery.AutoComplete是一个基于jQuery的自动补全插件.借助于jQuery优秀的跨浏览器特性,可以兼容Chrome/IE/Firefox/Opera/Safari等多种浏览器. 特 ...

  2. jquery autocomplete插件

    jquery autocomplete插件 https://goodies.pixabay.com/jquery/auto-complete/demo.html autocomplete-table ...

  3. jquery.autocomplete 模糊查询 支持分组

    //demo <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <lin ...

  4. 使用jQuery Autocomplete(自动完成)插件

    jQuery 的Autocomplete(自动完成.自动填充)插件有不少,但比较下来我感觉,还是bassistance.de 的比较强大,我们就来写一些代码感受一下. 最简单的Autocomplete ...

  5. jquery autocomplete实现读取sql数据库自动补全TextBox

    转自我本良人 原文 jquery autocomplete实现读取sql数据库自动补全TextBox 项目需要这样子一个功能,其他部门提的意见,只好去实现了哦,搞了好久才弄出来,分享一下. 1.前台页 ...

  6. Bootstrap Typeahead/Jquery autocomplete自动补全

    使用Bootstrap Typeahead 组件: Bootstrap 中的 Typeahead 组件就是通常所说的自动完成 AutoComplete,自动填充. 效果如图所示: 实现方式: 1.引入 ...

  7. [Jquery] Jquery AutoComplete的使用方法实例

    jQuery的Autocomplete(自动完成.自动填充)插件 jquery-autocomplete配置: <script type="text/javascript" ...

  8. JQuery UI Autocomplete与jquery.autocomplete.js

    程序中要把一个select改成可以下拉搜索的,就想到了使用下autocomplete.js大概是这么个东西. 问了下同学,推荐我使用Jquery Ui autocomplete,下载下来开始调试使用, ...

  9. [转]jQuery.Autocomplete实现自动完成功能(详解)

    本篇文章除了介绍jquery.autocomplete基本参数外,主要说明jquery.autocomplete的数据源的格式问题.     1.jquery.autocomplete参考地址 htt ...

随机推荐

  1. 无法连接mysql,请检查mysql是否已启动及用户密码是否设置正确

    安装好后,登录后台提示 无法连接mysql,请检查mysql是否已启动及用户密码是否设置正确 检查mysql是否启动netstat -lnpt是否有3306端口? 一 有A 检查/www/wdlinu ...

  2. php71

    yum -y install php-mcrypt libmcrypt libmcrypt-devel autoconf freetype gd jpegsrc libmcrypt libpng li ...

  3. zabbix_server.conf 详解

    # This is a configuration file for Zabbix server daemon # To get more information about Zabbix, visi ...

  4. Shc 应用

    1.说明 shc是一个加密shell脚本的工具, 它的作用是把shell脚本转换为一个可执行的二进制文件 2.安装 下载 # mget  http://www.datsi.fi.upm.es/~fro ...

  5. 51nod 1163 最高的奖励

    链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1163 1163 最高的奖励  基准时间限制:1 秒 空间限制:13 ...

  6. Shell教程 之字符串

    1.Shell字符串 字符串是shell编程中最常用最有用的数据类型(除了数字和字符串,也没啥其它类型好用了),字符串可以用单引号,也可以用双引号,也可以不用引号. 1.1 单引号 str='I am ...

  7. RxJS之转化操作符 ( Angular环境 )

    一 map操作符 类似于大家所熟知的 Array.prototype.map 方法,此操作符将投射函数应用于每个值 并且在输出 Observable 中发出投射后的结果. import { Compo ...

  8. 以太坊博弈游戏 -- FOMO3D,讽刺人性

    以下资料收录自各个博客,下面给出链接. 总的来说,这是基于以太坊的“菠菜”游戏,大资金盘,亏多盈少,大家看看就好. 官网地址:http://exitscam.me/play 出现 7月16日,当时这个 ...

  9. jdk与eclipse位数不一致出现的问题

    今天运行eclipse时出现了如下问题: 后来去网上查了一下,如果jdk版本的位数和eclipse安装版本所需要的版本位数不相同,就会出现如图所示的问题,导致eclipse打不开. 1.查询jdk版本 ...

  10. how2j网站前端项目——天猫前端(第一次)学习笔记8

    其他页面的学习 这些页面有1.查询结果页 2.支付页面 3.支付成功页面 4.确认收货页面上 5.确认收货页面下 6.收获成功页面 7.评价页面上 8.评价页面下 9.登陆页面 10.注册页面 1.查 ...