再说AutoComplete
2011-11-04 12:16 【当耐特】 阅读(5396) 评论(11) 编辑 收藏 举报一.简述
昨天support一同事,帮她的客户做类似下面的效果(自动完成):
以前在搜房的时候,弄过这个,调用楼盘字典:
这是一个小功能,也是一个大功能。因为它可以做大,也可以做小。
二.搜房的AutoComplete
比如上面我们看到搜房的这个就做大了,你要看到这样一个效果,其实搜房做了这么几件事:
1.数据库作业。把每天的楼盘字典存入XML,每个城市的对应一个XML.比如今天生成的bj_11_04.xml
2.业务逻辑层加上Memcached。用户访问的时候,先判断Memcached里有没有,有的话走缓存,没有的话读XML,并且入缓存。
3.AJAX调用
4.拼音调用楼盘字典(开始做了,后来又删了,原因不详),就是下面效果
所以,这个功能,可以做大,也可以做小。做大了要申请加服务器。所以做这个功能之前,要了解访问量。
三.Coding
下面说下昨天做的东西,完全基于JqueryUI,
ASPX代码:
1 2 3 4 5 6 7 8 9 10 | < link rel="stylesheet" href="Styles/jquery-ui.css" type="text/css" media="all" /> < 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 > |
后台代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 | public void ProcessRequest(HttpContext context) { string searchText = context.Request.QueryString[ "term" ]; //Get Result here //```` //```` //Get Result here JavaScriptSerializer serializer = new JavaScriptSerializer(); string jsonString = serializer.Serialize(results); context.Response.Write(jsonString); } |
可能有人会问,context.Request.QueryString["term"];中的term是怎么来的?我们通过aspx根本看不到term。
我们可以用任何浏览器的F12的NetWork抓出来:
上面是ASP.NET下的实现,在ASP.NET MVC2或者MVC3或者MVC4中,我们不用使用JavaScriptSerializer和ashx 这种方式来序列化成JSON并且向客户端write,因为它们提供了JSONResult
1 2 3 4 5 | public JsonResult GetResourceByKeyWord() { //get searchResult here return Json(searchResult, JsonRequestBehavior.AllowGet); } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?