AJAX实现百度谷歌搜索自动填充

本文介绍如何利用AJAX技术实现类似百度谷歌的搜索自动填充功能。通过一个文本框接收用户输入,结合AutoCompleteExtender控件及Webservice文件处理数据库查询,实现了输入时的动态提示。

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


         这篇博客做一个用AJAX实现百度谷歌搜索自动填充。大家在上网搜索资料的时候,搜索引擎都为我们显示出了人性化的自动提示功能,满足用户需求的同时也极大的方便了客户的操作,可谓是一箭双雕。现在的AJAX这种客户端和服务器交互式的编程技术可以说是应用及其的广泛,几乎大家每天上午都在和AJAX打交道。它让web应用程序显示出了C/S诸多好处,AJAX 在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求),客户端与服务器进行交互在不需要全部更新整个页面的时候基本都使的是AJAX技术。


       下面我们具体的说说百度谷歌是怎样自动填充的。它主要使用的有:

1.    一个文本框,用来输入数据

2.     AJAX Tool Kit中的一个控件AutoCompleteExtender,用来让文本框和数据源建立关系(AJAX Tool Kit需要大家去网上下载,将下载下来的dll文件添加到VS当中)

3.    一个用于获取数据库数据的文件 ,这个文件的类型没有限制,可以是Webservice(.asmx)和WCF(.svc)和一般处理程序(.ashx)文件,或者普通的C#类文件和文本文件也可以。我们在例子当中使用的是webservice

 

下面我们开始这个例子的制作过程:

一、建立部门的数据库,并在部门表(TDepartment)中添加数据




二、在aspx页面中添加控件(TextBox、ScriptManager、AutoCompleteExtender)并设定控件的属性,HTML代码如下所示:

 

<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
        <asp:ScriptManager ID="ScriptManager1" runat="server">
        </asp:ScriptManager>
        <cc1:AutoCompleteExtender ID="AutoCompleteExtender1" runat="server"
            TargetControlID="TextBox1"
            MinimumPrefixLength="1"
             ServiceMethod="GetDeptName"
             ServicePath="WebService1.asmx">
        </cc1:AutoCompleteExtender>


 

AutoCompleteExtender控件的属性:
   1.TargetControlID:指定将被辅助完成自动输入的控件ID,这里的控件只能是TextBox;
   2.ServicePath:指出提供服务的WEB服务路径,若不指出则ServiceMethod表示本页面对应的方法名;
   3.ServiceMethod:指出提供服务的方法名;
   4.MinimumPrefixLength:指出开始提供提示服务时,TextBox控件应有的最小字符数,默认为3;
   5.CompletionSetCount:显示的条数,默认为10;
   6.EnableCaching:是否在客户端缓存数据,默认为true;
   7.CompletionInterval:从服务器读取数据的时间间隔,默认为1000,单位:毫秒。

 

三、WebService1.asmx文件中函数GetDeptName的添加:

 

[WebMethod]
        public static string[] GetDeptName(stringprefixText)
        {
            List<string> suggestions = newList<string>();
            try
            {
 
                SqlConnectioncon = new SqlConnection("server=.;Initial Catalog=department;UserID=sa;Password=123456");
                SqlCommandcmd = new SqlCommand();
                //模糊查询使用“%”
                cmd.CommandText = "SELECT depName FROM TDepartment where depName like'" + prefixText + "%'";
                cmd.Connection = con;
                con.Open();
                SqlDataReadersdr = null;
                sdr = cmd.ExecuteReader();
                while(sdr.Read())
                {
                   suggestions.Add(sdr.GetSqlString(0).Value);
                }
 
                returnsuggestions.ToArray();
            }
 
            catch(System.Exception ex)
            {
                suggestions.Add(ex.Message);
                returnsuggestions.ToArray();
            }
 
 
        }


    到此为止我们的工作都已经完成了,效果拭目以待,大家试试看吧!




      下载代码


评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值