源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

再说AutoComplete自动补全之实现原理

  • 时间:2022-11-29 01:45 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:再说AutoComplete自动补全之实现原理
一.简述 昨天support一同事,帮她的客户做类似下面的效果(自动完成): [img]http://files.jb51.net/upload/201111/20111105131250411.png[/img] 以前在搜房的时候,弄过这个,调用楼盘字典: [img]http://files.jb51.net/upload/201111/20111105131250836.png[/img] 这是一个小功能,也是一个大功能。因为它可以做大,也可以做小。 [b]二.搜房的AutoComplete [/b]比如上面我们看到搜房的这个就做大了,你要看到这样一个效果,其实搜房做了这么几件事: 1.数据库作业。把每天的楼盘字典存入XML,每个城市的对应一个XML.比如今天生成的bj_11_04.xml 2.业务逻辑层加上Memcached。用户访问的时候,先判断Memcached里有没有,有的话走缓存,没有的话读XML,并且入缓存。 3.AJAX调用 4.拼音调用楼盘字典(开始做了,后来又删了,原因不详),就是下面效果 [img]http://files.jb51.net/upload/201111/20111105131250301.png[/img] 所以,这个功能,可以做大,也可以做小。做大了要申请加服务器。所以做这个功能之前,要了解访问量。 [b]三.Coding [/b]下面说下昨天做的东西,完全基于JqueryUI, ASPX代码:
[url=Styles/jquery-ui.css]<script type="text/javascript" src="Scripts/jquery.min.js"></script> <script type="text/javascript" src="Scripts/jquery-ui.min.js"></script> <script type="text/javascript"> $(function () { $('#tbSearch').autocomplete({ source: "AutoComplete.ashx" }); }); </script>
后台代码: 可能有人会问,context.Request.QueryString["term"];中的term是怎么来的?我们通过aspx根本看不到term。 我们可以用任何浏览器的F12的NetWork抓出来: [img]http://files.jb51.net/upload/201111/20111105131250432.png[/img] 上面是ASP.NET下的实现,在ASP.NET MVC2或者MVC3或者MVC4中,我们不用使用JavaScriptSerializer和ashx 这种方式来序列化成JSON并且向客户端write,因为它们提供了JSONResult
[u]复制代码[/u] 代码如下:
public JsonResult GetResourceByKeyWord() { //get searchResult here return Json(searchResult, JsonRequestBehavior.AllowGet); }
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部