再说AutoComplete自动补全之实现原理
2011-11-05 13:12
661 查看
一.简述
昨天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抓出来:
public JsonResult GetResourceByKeyWord()
{
//get searchResult here
return Json(searchResult, JsonRequestBehavior.AllowGet);
}
昨天support一同事,帮她的客户做类似下面的效果(自动完成):
以前在搜房的时候,弄过这个,调用楼盘字典:
这是一个小功能,也是一个大功能。因为它可以做大,也可以做小。
二.搜房的AutoComplete
比如上面我们看到搜房的这个就做大了,你要看到这样一个效果,其实搜房做了这么几件事:
1.数据库作业。把每天的楼盘字典存入XML,每个城市的对应一个XML.比如今天生成的bj_11_04.xml
2.业务逻辑层加上Memcached。用户访问的时候,先判断Memcached里有没有,有的话走缓存,没有的话读XML,并且入缓存。
3.AJAX调用
4.拼音调用楼盘字典(开始做了,后来又删了,原因不详),就是下面效果
所以,这个功能,可以做大,也可以做小。做大了要申请加服务器。所以做这个功能之前,要了解访问量。
三.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抓出来:
上面是ASP.NET下的实现,在ASP.NET MVC2或者MVC3或者MVC4中,我们不用使用JavaScriptSerializer和ashx 这种方式来序列化成JSON并且向客户端write,因为它们提供了JSONResult
public JsonResult GetResourceByKeyWord()
{
//get searchResult here
return Json(searchResult, JsonRequestBehavior.AllowGet);
}
您可能感兴趣的文章:
相关文章推荐
- 再说AutoComplete自动补全之实现原理
- bigautocomplete实现联想输入,自动补全
- bigautocomplete实现联想输入,自动补全
- JQueryAjaxAutocomplete实现自动补全
- bigautocomplete实现联想输入,自动补全
- Android控件使用—AutoCompleteTextView自动补全实现搜索功能
- java中用jquery AutoComplete 实现自动补全(一)简单小例子
- Android自定义AutoCompleteTextView实现自动补全Email
- 用jquery-ui Autocomplete一步一步实现输入自动补全
- jQuery自动补全autocomplete插件使用,三种获取数据源方式具体实现(true)
- bigautocomplete实现联想输入,自动补全
- android控件——AutoCompleteTextView(实现自动补全)
- jQuery autocomplete实现仿搜索引擎文本自动补全自动完成插件
- 自动补全(智能提示)原理与实现
- java中用jquery AutoComplete 实现自动补全(二)本地JSON实现自动补全
- jquery autocomplete实现读取sql数据库自动补全TextBox
- jQuery Autocomplete插件实现文本框内容自动匹配补全
- java中用jquery AutoComplete 实现自动补全(二)后台JSON实现自动补全
- java中用jquery AutoComplete 实现自动补全(二)本地JSON实现自动补全
- jquery autocomplete实现读取sql数据库自动补全TextBox