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

 更新时间:2011年11月05日 13:12:54   作者:  
再说AutoComplete自动补全之实现原理,这里以asp.net后台为主,考虑到性能最好是生成xml并入缓存。
一.简述
昨天support一同事,帮她的客户做类似下面的效果(自动完成):

image

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

image

这是一个小功能,也是一个大功能。因为它可以做大,也可以做小。
二.搜房的AutoComplete
比如上面我们看到搜房的这个就做大了,你要看到这样一个效果,其实搜房做了这么几件事:

1.数据库作业。把每天的楼盘字典存入XML,每个城市的对应一个XML.比如今天生成的bj_11_04.xml
2.业务逻辑层加上Memcached。用户访问的时候,先判断Memcached里有没有,有的话走缓存,没有的话读XML,并且入缓存。
3.AJAX调用
4.拼音调用楼盘字典(开始做了,后来又删了,原因不详),就是下面效果

image

所以,这个功能,可以做大,也可以做小。做大了要申请加服务器。所以做这个功能之前,要了解访问量。
三.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抓出来:

image

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

复制代码 代码如下:

public JsonResult GetResourceByKeyWord()
{
//get searchResult here
return Json(searchResult, JsonRequestBehavior.AllowGet);
}

相关文章

  • BootStrap树状图显示功能

    BootStrap树状图显示功能

    本文是小编根据bootstrap的折叠设计的树状图显示效果,只有二级显示,可以用在简单的目录等。对实现代码感兴趣的朋友可以参考下本文
    2016-11-11
  • jQuery实现复选框的全选和反选

    jQuery实现复选框的全选和反选

    本文主要分享了使用jQuery实现复选框的全选和反选的示例代码。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • jQuery控制frames及frame页面JS的方法

    jQuery控制frames及frame页面JS的方法

    这篇文章主要介绍了jQuery控制frames及frame页面JS的方法,涉及jQuery针对页面元素的判定及frame框架的操作技巧,需要的朋友可以参考下
    2016-03-03
  • 五步轻松实现zTree的使用

    五步轻松实现zTree的使用

    这篇文章主要为大家详细介绍了五个步骤轻松实现zTree的使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • JQuery中绑定事件(bind())和移除事件(unbind())

    JQuery中绑定事件(bind())和移除事件(unbind())

    本文主要向大家详细介绍了jQuery的绑定事件和移除事件的使用方法和示例分享,这里推荐给有需要的小伙伴们参考下。
    2015-02-02
  • Jquery中Event对象属性小结

    Jquery中Event对象属性小结

    这篇文章主要介绍了Jquery中Event对象属性的操作方法的总结,非常的详细,是篇十分不错的文章,这里推荐给大家。
    2015-02-02
  • jQuery解析json格式数据简单实例

    jQuery解析json格式数据简单实例

    这篇文章主要介绍了jQuery解析json格式数据的方法,结合实例分析了使用jQuery1.7.2版本的方法解析json格式数据的技巧,需要的朋友可以参考下
    2016-01-01
  • 正负小数点后两位浮点数实现原理及代码

    正负小数点后两位浮点数实现原理及代码

    需要做个对两位小数点的正负浮点数的处理要求:非数字或者.字符自动清除,并对.12自动修补.前的0,实现原理如下,感兴趣的朋友可以参考下
    2013-09-09
  • jQuery实现评论模块

    jQuery实现评论模块

    这篇文章主要为大家详细介绍了jQuery实现评论模块,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • jquery快捷动态绑定键盘事件的操作函数代码

    jquery快捷动态绑定键盘事件的操作函数代码

    动态绑定键盘事件的方法或许会有很多,在本文将为大家介绍下jquery是如何快捷实现的,感兴趣的朋友不要错过
    2013-10-10

最新评论