zoukankan      html  css  js  c++  java
  • 再说AutoComplete

    一.简述

    昨天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);
    }
  • 相关阅读:
    批量SSH操作工具---OmniTTY安装
    CentOS6.6修改主机名和网络信息
    浪潮服务器通过ipmitool获取mac地址
    linux批量执行工具omnitty使用方法
    操作系统下查看HBA卡信息wwn的方法
    Linux下multipath多路径配置
    IPMITOOL 配置BMC用户设置
    第五讲 对于耦合的认识 target/action设计模式 delegate设计模式 手势识别器
    UI第四讲.事件处理(按钮点击切换视图,触摸事件)
    UI第三讲.自定义视图 视图控制器 检测屏幕旋转
  • 原文地址:https://www.cnblogs.com/iamzhanglei/p/2235914.html
Copyright © 2011-2022 走看看