再说AutoComplete自动补全之实现原理 |
一.简述 昨天support一同事,帮她的客户做类似下面的效果(自动完成): 以前在搜房的时候,弄过这个,调用楼盘字典: 这是一个小功能,也是一个大功能 。因为它可以做大,也可以做小 。 所以,这个功能,可以做大,也可以做小 。做大了要申请加服务器 。所以做这个功能之前,要了解访问量 。 复制代码 代码如下: <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> 后台代码: 复制代码 代码如下: 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 复制代码 代码如下: public JsonResult GetResourceByKeyWord() { //get searchResult here return Json(searchResult, JsonRequestBehavior.AllowGet); } |