jQuery UI Autocomplete 体验分享


Posted in Javascript onFebruary 14, 2012

支持的数据源
jQuery UI Autocomplete主要支持字符串Array、JSON两种数据格式。
普通的Array格式没有什么特殊的,如下:

["cnblogs","博客园","?逶?]

对于JSON格式的Array,则要求有:label、value属性,如下:
[{label: "博客园", value: "cnblogs"}, {label: "?逶?, value: "?逶?}]

其中label属性用于显示在autocomplete弹出菜单,而value属性则是选中后给文本框赋的值。
如果没有指定其中一个属性则用另一个属性替代(即value和label值一样),如下:
[{label: "cnblogs"}, {label: "?逶?}] 
[{value: "cnblogs"}, {value: "?逶?}]

如果label和value都没有指定,则无法用于autocomplete的提示。
另外需要注意,对于从服务器端输出的JSON的key必须用双引号,如下:
[{"label": "博客园", "value": "cnblogs"}, {"label": "?逶?, "value": "?逶?}]

否则可能会出现parsererror错误。
主要的参数
jQuery UI Autocomplete常用的参数有:
Source:用于指定数据来源,类型为String、Array、Function
String:用于ajax请求的服务器端地址,返回Array/JSON格式
Array:即字符串数组 或 JSON数组
Function(request, response):通过request.term获得输入的值,response([Array])来呈现数据;(JSONP是这种方式)
minLength:当输入框内字符串长度达到minLength时,激活Autocomplete
autoFocus:当Autocomplete选择菜单弹出时,自动选中第一个
delay:即延迟多少毫秒激活Autocomplete
其他不常用的就不罗列了。
使用方法
假如页面上有以下输入框:
<input type="text" id="autocomp" />
AJAX请求
通过指定source为服务器端的地址来实现,如下:
$("#autocomp").autocomplete({ 
source: "remote.ashx", 
minLength: 2 
});

然后在服务器端接收,并输出相应结果,注意默认传递的参数名称为term:
public void ProcessRequest(HttpContext context) 
{ 
// 查询的参数名称默认为term 
string query = context.Request.QueryString["term"]; 
context.Response.ContentType = "text/javascript"; 
//输出字符串数组 或者 JSON 数组 
context.Response.Write("[{\"label\":\"博客园\",\"value\":\"cnblogs\"},{\"label\":\"?逶?",\"value\":\"?逶?"}]"); 
}

本地Array/JSON数组
// 本地字符串数组 
var availableTags = [ 
"C#", 
"C++", 
"Java", 
"JavaScript", 
"ASP", 
"ASP.NET", 
"JSP", 
"PHP", 
"Python", 
"Ruby" 
]; 
$("#local1").autocomplete({ 
source: availableTags 
}); 
// 本地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" } 
]; 
$("#local2").autocomplete({ 
source: availableTagsJSON 
});

Callback Function方式
通过指定source为自定义函数来实现自定义数据的获取,函数主要有2个参数(request,response),分别用于获取输入的值、呈现结果
本地Array方式获取数据(模仿新浪微博的登录)
var hosts = ["gmail.com", "live.com", "hotmail.com", "yahoo.com", "cnblogs.com", "火星.com", "?逶?com"]; 
$("#email1").autocomplete({ 
autoFocus: true, 
source: function(request, response) { 
var term = request.term, //request.term为输入的字符串 
ix = term.indexOf("@"), 
name = term, // 用户名 
host = "", // 域名 
result = []; // 结果 
result.push(term); 
// result.push({ label: term, value: term }); // json格式 
if (ix > -1) { 
name = term.slice(0, ix); 
host = term.slice(ix + 1); 
} 
if (name) { 
var findedHosts = (host ? $.grep(hosts, function(value) { 
return value.indexOf(host) > -1; 
}) : hosts), 
findedResults = $.map(findedHosts, function(value) { 
return name + "@" + value; //返回字符串格式 
// return { label: name + " @ " + value, value: name + "@" + value }; // json格式 
}); 
result = result.concat($.makeArray(findedResults)); 
} 
response(result);//呈现结果 
} 
});

JSONP方式获取数据
直接从官方DEMO拿来的,通过发送ajax请求到远程服务器,然后对返回结果进行处理,最后通过response来呈现:
$("#jsonp").autocomplete({ 
source: function(request, response) { 
$.ajax({ 
url: "http://ws.geonames.org/searchJSON", 
dataType: "jsonp", 
data: { 
featureClass: "P", 
style: "full", 
maxRows: 12, 
name_startsWith: request.term 
}, 
success: function(data) { 
response($.map(data.geonames, function(item) { 
return { 
label: item.name + (item.adminName1 ? ", " + item.adminName1 : "") + ", " + item.countryName, 
value: item.name 
} 
})); 
} 
}); 
}, 
minLength: 2 
});

主要的事件
jQuery UI Autocomplete有一些事件,可用于在一些阶段进行额外的控制:
create(event, ui):Autocomplete创建时,可以在此事件中,对外观进行一些控制
search(event, ui): 在开始请求之前,可以在此事件中返回false来取消请求
open(event, ui):Autocomplete的结果列表弹出时
focus(event, ui):Autocomplete的结果列表任意一项获得焦点时,ui.item为获得焦点的项
select(event, ui):Autocomplete的结果列表任意一项选中时,ui.item为选中的项
close(event, ui):Autocomplete的结果列表关闭时
change(event, ui):当值改变时,ui.item为选中的项
这些事件的ui参数的item属性(如果有的话)默认有label和value属性,不管在source中设置的数据是Array还是JSON数组,如下3种:
["cnblogs","博客园","?逶?] 
[{label: "博客园", value: "cnblogs"}, {label: "?逶?, value: "?逶?}] 
[{label: "博客园", value: "cnblogs", id: "1"}, {label: "?逶?, value: "?逶?, id: "2"}]

假如是第三种的话,还可以得到ui.item.id的值。
这些事件可以通过2种方式来绑定,如下:
// 在参数中 
$("#autocomp").autocomplete({ 
source: availableTags 
, select: function(e, ui) { 
alert(ui.item.value) 
} 
}); 
// 通过bind来绑定 
$("#autocomp").bind("autocompleteselect", function(e, ui) { 
alert(ui.item.value); 
});

通过bind来绑定的方式使用的事件名称为"autocomplete"+事件名称,如"select"就是"autocompleteselect"。
多个值的Autocomplete
一般情况下,输入框的autocomplete仅需要一个值就可以(如:javascript);假如需要多个值(如:javascript,c#,asp.net),则需要绑定一些事件来进行额外处理:
在focus事件中返回false,避免输入框的值被autocomplete的单个值取代
在select事件中组合多个值
在元素的keydown事件做一些处理,理由同1
使用callback function方式的source,来获取最后输入的值,并呈现结果
还是直接拿官方DEMO的代码:
// 按逗号分隔多个值 
function split(val) { 
return val.split(/,\s*/); 
} 
// 提取输入的最后一个值 
function extractLast(term) { 
return split(term).pop(); 
} 
// 按Tab键时,取消为输入框设置value 
function keyDown(event) { 
if (event.keyCode === $.ui.keyCode.TAB && 
$(this).data("autocomplete").menu.active) { 
event.preventDefault(); 
} 
} 
var options = { 
// 获得焦点 
focus: function() { 
// prevent value inserted on focus 
return false; 
}, 
// 从autocomplete弹出菜单选择一个值时,加到输入框最后,并以逗号分隔 
select: function(event, ui) { 
var terms = split(this.value); 
// remove the current input 
terms.pop(); 
// add the selected item 
terms.push(ui.item.value); 
// add placeholder to get the comma-and-space at the end 
terms.push(""); 
this.value = terms.join(", "); 
return false; 
} 
}; 
// 多个值,本地数组 
$("#local3").bind("keydown", keyDown) 
.autocomplete($.extend(options, { 
minLength: 2, 
source: function(request, response) { 
// delegate back to autocomplete, but extract the last term 
response($.ui.autocomplete.filter( 
availableTags, extractLast(request.term))); 
} 
})); 
// 多个值,ajax返回json 
$("#ajax3").bind("keydown", keyDown) 
.autocomplete($.extend(options, { 
minLength: 2, 
source: function(request, response) { 
$.getJSON("remoteJSON.ashx", { 
term: extractLast(request.term) 
}, response); 
} 
}));

结尾
最后,放上代码:点击下载。
更多的资料请看jQuery UI Autocomplete官方演示:http://jqueryui.com/demos/autocomplete
Javascript 相关文章推荐
些很实用且必用的小脚本代码
Jun 26 Javascript
Javascript注入技巧
Jun 22 Javascript
Javascript中获取出错代码所在文件及行数的代码
Sep 23 Javascript
Jquery之美中不足小结
Feb 16 Javascript
jQuery.fn和jQuery.prototype区别介绍
Oct 05 Javascript
javascript获取所有同类checkbox选项(实例代码)
Nov 07 Javascript
javascript图片预览和上传(兼容IE)
Mar 15 Javascript
JS实现线性表的顺序表示方法示例【经典数据结构】
Apr 11 Javascript
深入浅析Vue中的 computed 和 watch
Jun 06 Javascript
在vue中更换字体,本地存储字体非引用在线字体库的方法
Sep 28 Javascript
详解如何构建Promise队列实现异步函数顺序执行
Oct 23 Javascript
jQuery Ajax async=&gt;false异步改为同步时,解决导致浏览器假死的问题
Jul 22 jQuery
JavaScript/jQuery 表单美化插件小结
Feb 14 #Javascript
Firefox/Chrome/Safari的中可直接使用$/$$函数进行调试
Feb 13 #Javascript
情人节之礼 js项链效果
Feb 13 #Javascript
jQuery.getScript加载同域JS的代码
Feb 13 #Javascript
理解JavaScript的prototype属性
Feb 11 #Javascript
情人节专属 纯js脚本1k大小的3D玫瑰效果
Feb 11 #Javascript
基于jquery实现状态限定编辑的代码
Feb 11 #Javascript
You might like
MySQL相关说明
2007/01/15 PHP
PHP中全面阻止SQL注入式攻击分析小结
2012/01/30 PHP
php FLEA中二叉树数组的遍历输出
2012/09/26 PHP
php防注入及开发安全详细解析
2013/08/09 PHP
php读取qqwry.dat ip地址定位文件的类实例代码
2016/11/15 PHP
Yii2设置默认控制器的两种方法
2017/05/19 PHP
PHP基于PDO实现的SQLite操作类【包含增删改查及事务等操作】
2017/06/21 PHP
javascript 动态设置已知select的option的value值的代码
2009/12/16 Javascript
js前台判断开始时间是否小于结束时间
2012/02/23 Javascript
JS中的prototype与面向对象的实例讲解
2013/05/22 Javascript
JS获取当前网址、主机地址项目根路径
2013/11/19 Javascript
xmlhttp缓存清除的2种解决方法
2013/12/13 Javascript
分享33个jQuery与CSS3实现的绚丽鼠标悬停效果
2014/12/15 Javascript
JavaScript Math.ceil 方法(对数值向上取整)
2015/01/09 Javascript
javaScript数组迭代方法详解
2016/04/14 Javascript
微信小程序通过api接口将json数据展现到小程序示例
2017/01/20 Javascript
Jquery EasyUI $.Parser
2017/06/02 jQuery
原生JS实现图片网格式渐显、渐隐效果
2017/06/05 Javascript
vue better scroll 无法滚动的解决方法
2018/06/07 Javascript
基于Vue实现微信小程序的图文编辑器
2018/07/25 Javascript
python中函数总结之装饰器闭包详解
2016/06/12 Python
Python中实现变量赋值传递时的引用和拷贝方法
2018/04/29 Python
python实现txt文件格式转换为arff格式
2018/05/31 Python
python: 判断tuple、list、dict是否为空的方法
2018/10/22 Python
详解如何管理多个Python版本和虚拟环境
2019/05/10 Python
python3实现猜数字游戏
2020/12/07 Python
如何更优雅地写python代码
2019/07/02 Python
Django静态资源部署404问题解决方案
2020/05/11 Python
如何将json数据转换为python数据
2020/09/04 Python
canvas环形倒计时组件的示例代码
2018/06/14 HTML / CSS
中级会计职业生涯规划书
2014/03/01 职场文书
就业协议书盖章的注意事项
2014/09/28 职场文书
地震慰问信
2015/02/14 职场文书
企业法人代表证明书
2015/06/18 职场文书
退休劳动合同怎么写?
2019/10/25 职场文书
springboot拦截器无法注入redisTemplate的解决方法
2021/06/27 Java/Android