jQuery 入门教程(25): jQuery UI Autocomplete示例(三)

本文介绍如何利用jQuery的AJAX函数结合JSONP技术,实现在用户输入时提供城市名称自动补全的功能。通过配置AutoComplete组件的数据源为一个远程WebService,根据用户的输入请求相关数据,并在响应中筛选并返回匹配的城市名称。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

AutoComplete在用户输入时,可以根据用户输入给出提示。其数据源可以来自本地,也可以使用远程数据源,AutoComplete 的DataSource可以使用一个Function,本篇中的Function,我们使用JSONP查询。 
当数据源为Function时,其函数定义为:
Function( Object request, Function response( Object data))
其中 request 为请求,它含有一个term属性,为当前用户输入。
response 为一回调函数,它有一个参数data,用来提示用户的数据,这个值理应根据输入的term进行过滤。
本例使用由genames提供的Web Service。可以查询世界的城市名称。使用了jQuery 提供的.ajax 函数来访问这个Web Service.

1 $("#city").autocomplete({
2 source:function( request, response ) {
3 $.ajax({
4 url:"http://ws.geonames.org/searchJSON",
5 dataType:"jsonp",
6 data: {
7 featureClass:"P",
8 style:"full",
9 maxRows: 12,
10 name_startsWith: request.term
11 },
12 success:function( data ) {
13 response( $.map( data.geonames,function( item ) {
14 return{
15 label: item.name + (item.adminName1 ?", "
16 + item.adminName1 :"") +", "+ item.countryName,
17 value: item.name
18 };
19 }));
20 }
21 });
22 },

20130316005

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值