2
回答
jQueryUI实战之Autocomplete组件的JSONP使用
开发十年,就只剩下这套Java开发体系了   

作者:Terry li - GBin1.com

Autocomplete是jQueryUI中新加入的俩个组件之一,它提供了方便简介的方式来自动帮助用户完成输入过程。在web前台开发过程中,我们 往往需要在搜索对话框中加入相关功能来方便用户使用。今天我们主要介绍其中跨域数据源的使用,即JSONP。下面我先简单介绍一下JSONP。

什么是JSONP

JSONP是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问(这仅仅是JSONP简单的实现形式)。

如何使用JSONP

1. 在客户端调用提供JSONP支持的远程URL Service,用来获取JSONP格式数据。

如何客户想访问http://www.gbin1.com/service.aspx?jsonp=callbackFunction
假设客户期望返回JSON数据:["customername1","customername2"]
那么真正返回到客户端的响应内容: callbackFunction(["customername1","customername2"])

Autocomplete中的使用

autocomplete中集成了JSONP的数据源调用方式,所以远端你只需要实现如下:
提供远端的服务,例如,http://www.gbin1.com/technology/jquery/devgadgetforwindowsbyjquery/data.jsp
这个远端服务接受俩个参数:

  • name
  • callback

其中term是你提交到远端的查询内容,即用户输入内容,callback是autocomplete产生的callback函数名字,这里autocomplete会后台生成,我们无须关心。

原文及其代码演示请参考:jQueryUI实战之Autocomplete组件的JSONP使用

 

举报
gbin1
发帖于7年前 2回/1K+阅
共有2个评论 最后回答: 2年前

实现一个智能提示功能需要ajax、数据库、jsp/php、算法等很多知识,
如果数据量大,还需要特殊优化
一个小功能,花费太大精力很不划算
92find.com上的一个js插件实现了搜索框自动补全托管服务,
只要一行javascript代码就可以实现百度、淘宝搜索框提示的全部功能
比如:汉字拼音匹配、拼音首字母匹配、模糊搜索、智能容错,还可以自定义提示词汇及其排序权重
花五分钟我的网站就可以部署同百度、淘宝一样强大好用的输入提示功能
同时兼容IE、Firefox、Safari、Chrome、Opera各种浏览器
兼容ios、Android、Windows

顶部