ASP.NET中如何使用AutoComplete控件

发布时间:2021-07-15 14:48:21 作者:Leah
来源:亿速云 阅读:160

这期内容当中小编将会给大家带来有关ASP.NET中如何使用AutoComplete控件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

重要属性

1.TargetControlID:指定要实现提示功能的控件;

2.ServicePath:WebService的路径,提取数据的方法是写在一个WebService中的;

3.ServeiceMethod:写在WebService中的用于提取数据的方法的名字;

4.MinimumPrefixLength:用来设置用户输入多少字母才出现提示效果;

5.CompletionSetCount:设置提示数据的行数;

6.CompletionInterval:从服务器获取书的时间间隔,单位是毫秒。

示例

打开vs2005创建一个AjaxControlToolKit网站。

在网站的App_Data文件夹下添加文本文件TextFile.txt,并在其中添加数据,如下:

ASP.NET中如何使用AutoComplete控件

在网站的根目录下添加一个Web服务,命名为oec2003_AutoComplete,系统自动将Web服务两个部分,设计部分oec2003_AutoComplete.asmx和代码部分oec2003_AutoComplete.cs,其中oec2003_AutoComplete.cs文件自动放入到App_Code目录下。打开oec2003_AutoComplete.cs文件,添加获取数据的方法GetCompleteList,代码如下:

using System;
using System.Web;
using System.Collections;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.IO;

 
/// <summary>/// AutoComplete 的摘要说明
/// <summary>[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.Web.Script.Services.ScriptService]
public class AutoComplete : System.Web.Services.WebService {

    public AutoComplete () {

        //如果使用设计的组件,请取消注释以下行 
        //InitializeComponent(); 
    }

    [WebMethod]
    public string HelloWorld() {
        return "Hello World";
    }
    /// <summary>/// 获取数据的方法GetCompleteList
    /// <summary>//定义静态数组用于保存获取的数据
    private static string[] autoCompleteWordList = null;
    [WebMethod]
    public String[] GetCompleteList(string prefixText, int count)
    {
        if (autoCompleteWordList == null)
        {
            string[] temp = File.ReadAllLines(Server.MapPath("~/App_Data/TextFile.txt"));
            Array.Sort(temp, new CaseInsensitiveComparer());
            autoCompleteWordList = temp;
        }

        int index = Array.BinarySearch(autoCompleteWordList, prefixText, new CaseInsensitiveComparer());
        if (index < 0)
        {
            index = ~index;
        }

        int matchingCount;
        for (matchingCount = 0; matchingCount < count && index + matchingCount < autoCompleteWordList.Length; matchingCount++)
        {
            if (!autoCompleteWordList[index + matchingCount].StartsWith(prefixText, StringComparison.CurrentCultureIgnoreCase))
            {
                break;
}
        }
        String[] returnValue = new string[matchingCount];
        if (matchingCount > 0)
       {
           Array.Copy(autoCompleteWordList, index, returnValue, 0, matchingCount);
        }
        return returnValue;
    }

}

由于在上面的代码中使用了File类,所以应该添加如下代码:

using System.IO;

因为需要在客户端调用Web服务,还需要添加如下代码:

[System.Web.Script.Services.ScriptService]

保存Web 服务的代码

打开根目录下默认生成的Default.aspx

在页面中拖拽一个TextBox控件和一个AutoCompleteExtender控件。

在属性窗口设置AutoCompleteExtender控件的属性,如下

<ajaxToolkit:AutoCompleteExtender 
            ID="AutoCompleteExtender1" 
            runat="server" 
            ServiceMethod="GetCompleteList" 
            ServicePath="oec2003_AutoComplete.asmx" 
            Enabled="true" 
            MinimumPrefixLength="2" 
               CompletionSetCount="10"
            TargetControlID="TextBox1">
</ajaxToolkit:AutoCompleteExtender>

在Web服务中的count参数的值是取CompletionSetCount属性的值。

上述就是小编为大家分享的ASP.NET中如何使用AutoComplete控件了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. Asp.net 中GridView控件如何使用
  2. asp.net中如何使用控件

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

autocomplete asp.net  

上一篇:vue-router路径计算的示例分析

下一篇:javascript如何编写简易计算器

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》