再说AutoComplete

本文介绍如何使用JQuery UI实现输入框自动完成功能,包括前后端交互及实现细节。通过示例代码展示了ASP.NET环境下自动完成功能的具体实现过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.简述

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

image

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

image

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

 

 

二.搜房的AutoComplete

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

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

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

3.AJAX调用

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

image

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

 

 

三.Coding

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

ASPX代码:

1
2
3
4
5
6
7
8
9
10
< 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 >

后台代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
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

1
2
3
4
5
public  JsonResult GetResourceByKeyWord()
{
     //get searchResult here
     return  Json(searchResult, JsonRequestBehavior.AllowGet);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值