手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >再说AutoComplete自动补全之实现原理
再说AutoComplete自动补全之实现原理
摘要:一.简述昨天support一同事,帮她的客户做类似下面的效果(自动完成):以前在搜房的时候,弄过这个,调用楼盘字典:这是一个小功能,也是一个...

一.简述

昨天support一同事,帮她的客户做类似下面的效果(自动完成):

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

以前在搜房的时候,弄过这个,调用楼盘字典:

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

这是一个小功能,也是一个大功能。因为它可以做大,也可以做小。

二.搜房的AutoComplete

比如上面我们看到搜房的这个就做大了,你要看到这样一个效果,其实搜房做了这么几件事:

1.数据库作业。把每天的楼盘字典存入XML,每个城市的对应一个XML.比如今天生成的bj_11_04.xml

2.业务逻辑层加上Memcached。用户访问的时候,先判断Memcached里有没有,有的话走缓存,没有的话读XML,并且入缓存。

3.AJAX调用

4.拼音调用楼盘字典(开始做了,后来又删了,原因不详),就是下面效果

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

所以,这个功能,可以做大,也可以做小。做大了要申请加服务器。所以做这个功能之前,要了解访问量。

三.Coding

下面说下昨天做的东西,完全基于JqueryUI,

ASPX代码:

复制代码 代码如下:

<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抓出来:

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

上面是ASP.NET下的实现,在ASP.NET MVC2或者MVC3或者MVC4中,我们不用使用JavaScriptSerializer和ashx 这种方式来序列化成JSON并且向客户端write,因为它们提供了JSONResult

复制代码 代码如下:

public JsonResult GetResourceByKeyWord()

{

//get searchResult here

return Json(searchResult, JsonRequestBehavior.AllowGet);

}

【再说AutoComplete自动补全之实现原理】相关文章:

nodejs调试cmd命令实现复制目录

解析javascript中鼠标滚轮事件

将HTML自动转为JS代码

jQuery实现html表格动态添加新行的方法

多个iframe自动调整大小的问题

生成html静态文件后的分页(客户端版)

AspNet中使用JQuery boxy插件的确认框

多种js图片预加载实现方式分享

JavaScript中eval函数的问题

探索angularjs+requirejs全面实现按需加载的套路

精品推荐
分类导航