以前见到google和迅雷等网站在搜索文本框中输入文字后能自动提示,感觉这种功能很炫也很实用.现在在学习asp.net ajax 发现AjaxControlToolKit工具包中的AutoComplete控件就能实现这种功能,而且非常简单.

    简介:

    AutoComplete控件就是在用户在文本框输入前几个字母或是汉字的时候,该控件就能从存放数据的文或是数据库里将所有以这些字母开头的数据提示给用户,供用户选择,提供方便.


    重要属性

    1、TargetControlID:指定要实现提示功能的控件。

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

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

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

    5、CompletionSetCount:设置提示数据的行数。

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


    示例

打开vs2005创建一个AjaxControlToolKit网站。

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

asp.net Ajax ---AutoComplete控件使用_asp.net


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


 1 asp.net Ajax ---AutoComplete控件使用_ajax_02using

 System;

 2 asp.net Ajax ---AutoComplete控件使用_ajax_02

using  System.Web;

 3 asp.net Ajax ---AutoComplete控件使用_ajax_02

using  System.Collections;

 4 asp.net Ajax ---AutoComplete控件使用_ajax_02

using  System.Web.Services;

 5 asp.net Ajax ---AutoComplete控件使用_ajax_02

using  System.Web.Services.Protocols;

 6 asp.net Ajax ---AutoComplete控件使用_ajax_02

using  System.IO;

 7 asp.net Ajax ---AutoComplete控件使用_ajax_02

 8 asp.net Ajax ---AutoComplete控件使用_ajax_02

 9 asp.net Ajax ---AutoComplete控件使用_ajax_10asp.net Ajax ---AutoComplete控件使用_webservice_11

/**/ /// <summary>

10asp.net Ajax ---AutoComplete控件使用_autocomplete_12/// AutoComplete 的摘要说明

11asp.net Ajax ---AutoComplete控件使用_ajax_13/// </summary>


12

asp.net Ajax ---AutoComplete控件使用_ajax_02[WebService(Namespace 

=   " http://tempuri.org/ " )]

13 asp.net Ajax ---AutoComplete控件使用_ajax_02[WebServiceBinding(ConformsTo 

=  WsiProfiles.BasicProfile1_1)]

14 asp.net Ajax ---AutoComplete控件使用_ajax_02[System.Web.Script.Services.ScriptService]

15 asp.net Ajax ---AutoComplete控件使用_ajax_10asp.net Ajax ---AutoComplete控件使用_webservice_11

public   class  AutoComplete : System.Web.Services.WebService  asp.net Ajax ---AutoComplete控件使用_asp.net_19

{

16asp.net Ajax ---AutoComplete控件使用_autocomplete_12

17asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22    public AutoComplete () asp.net Ajax ---AutoComplete控件使用_asp.net_19{

18asp.net Ajax ---AutoComplete控件使用_autocomplete_12

19asp.net Ajax ---AutoComplete控件使用_autocomplete_12        //如果使用设计的组件,请取消注释以下行 

20asp.net Ajax ---AutoComplete控件使用_autocomplete_12        //InitializeComponent(); 

21asp.net Ajax ---AutoComplete控件使用_autocomplete_27    }

22asp.net Ajax ---AutoComplete控件使用_autocomplete_12

23asp.net Ajax ---AutoComplete控件使用_autocomplete_12    [WebMethod]

24asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22    public string HelloWorld() asp.net Ajax ---AutoComplete控件使用_asp.net_19{

25asp.net Ajax ---AutoComplete控件使用_autocomplete_12        return "Hello World";

26asp.net Ajax ---AutoComplete控件使用_autocomplete_27    }

27asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22    /**//// <summary>

28asp.net Ajax ---AutoComplete控件使用_autocomplete_12    /// 获取数据的方法GetCompleteList

29asp.net Ajax ---AutoComplete控件使用_autocomplete_27    /// </summary>

30asp.net Ajax ---AutoComplete控件使用_autocomplete_12    //定义静态数组用于保存获取的数据

31asp.net Ajax ---AutoComplete控件使用_autocomplete_12    private static string[] autoCompleteWordList = null;

32asp.net Ajax ---AutoComplete控件使用_autocomplete_12    [WebMethod]

33asp.net Ajax ---AutoComplete控件使用_autocomplete_12    public String[] GetCompleteList(string prefixText, int count)

34asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22    asp.net Ajax ---AutoComplete控件使用_asp.net_19{

35asp.net Ajax ---AutoComplete控件使用_autocomplete_12        if (autoCompleteWordList == null)

36asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22        asp.net Ajax ---AutoComplete控件使用_asp.net_19{

37asp.net Ajax ---AutoComplete控件使用_autocomplete_12            string[] temp = File.ReadAllLines(Server.MapPath("~/App_Data/TextFile.txt"));

38asp.net Ajax ---AutoComplete控件使用_autocomplete_12            Array.Sort(temp, new CaseInsensitiveComparer());

39asp.net Ajax ---AutoComplete控件使用_autocomplete_12            autoCompleteWordList = temp;

40asp.net Ajax ---AutoComplete控件使用_autocomplete_27        }

41asp.net Ajax ---AutoComplete控件使用_autocomplete_12

42asp.net Ajax ---AutoComplete控件使用_autocomplete_12        int index = Array.BinarySearch(autoCompleteWordList, prefixText, new CaseInsensitiveComparer());

43asp.net Ajax ---AutoComplete控件使用_autocomplete_12        if (index < 0)

44asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22        asp.net Ajax ---AutoComplete控件使用_asp.net_19{

45asp.net Ajax ---AutoComplete控件使用_autocomplete_12            index = ~index;

46asp.net Ajax ---AutoComplete控件使用_autocomplete_27        }

47asp.net Ajax ---AutoComplete控件使用_autocomplete_12

48asp.net Ajax ---AutoComplete控件使用_autocomplete_12        int matchingCount;

49asp.net Ajax ---AutoComplete控件使用_autocomplete_12        for (matchingCount = 0; matchingCount < count && index + matchingCount < autoCompleteWordList.Length; matchingCount++)

50asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22        asp.net Ajax ---AutoComplete控件使用_asp.net_19{

51asp.net Ajax ---AutoComplete控件使用_autocomplete_12            if (!autoCompleteWordList[index + matchingCount].StartsWith(prefixText, StringComparison.CurrentCultureIgnoreCase))

52asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22            asp.net Ajax ---AutoComplete控件使用_asp.net_19{

53asp.net Ajax ---AutoComplete控件使用_autocomplete_12                break;

54asp.net Ajax ---AutoComplete控件使用_autocomplete_27            }

55asp.net Ajax ---AutoComplete控件使用_autocomplete_27        }

56asp.net Ajax ---AutoComplete控件使用_autocomplete_12        String[] returnValue = new string[matchingCount];

57asp.net Ajax ---AutoComplete控件使用_autocomplete_12        if (matchingCount > 0)

58asp.net Ajax ---AutoComplete控件使用_autocomplete_21asp.net Ajax ---AutoComplete控件使用_autocomplete_22        asp.net Ajax ---AutoComplete控件使用_asp.net_19{

59asp.net Ajax ---AutoComplete控件使用_autocomplete_12            Array.Copy(autoCompleteWordList, index, returnValue, 0, matchingCount);

60asp.net Ajax ---AutoComplete控件使用_autocomplete_27        }

61asp.net Ajax ---AutoComplete控件使用_autocomplete_12        return returnValue;

62asp.net Ajax ---AutoComplete控件使用_autocomplete_27    }

63asp.net Ajax ---AutoComplete控件使用_autocomplete_12

64asp.net Ajax ---AutoComplete控件使用_ajax_13}


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


asp.net Ajax ---AutoComplete控件使用_ajax_02using  System.IO;


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


asp.net Ajax ---AutoComplete控件使用_ajax_02[System.Web.Script.Services.ScriptService]


保存Web 服务的代码




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


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


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


asp.net Ajax ---AutoComplete控件使用_ajax_02<

ajaxToolkit:AutoCompleteExtender 

asp.net Ajax ---AutoComplete控件使用_ajax_02            ID

= " AutoCompleteExtender1 "  

asp.net Ajax ---AutoComplete控件使用_ajax_02            runat

= " server "  

asp.net Ajax ---AutoComplete控件使用_ajax_02            ServiceMethod

= " GetCompleteList "  

asp.net Ajax ---AutoComplete控件使用_ajax_02            ServicePath

= "oec2003_ AutoComplete.asmx "  

asp.net Ajax ---AutoComplete控件使用_ajax_02            Enabled

= " true "  

asp.net Ajax ---AutoComplete控件使用_ajax_02            MinimumPrefixLength

= " 2 "  

               CompletionSetCount="10"

asp.net Ajax ---AutoComplete控件使用_ajax_02            TargetControlID

= " TextBox1 " >

asp.net Ajax ---AutoComplete控件使用_ajax_02

</ ajaxToolkit:AutoCompleteExtender >

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

保存设计的页面,将默认页面设置为起始页,按F5运行后在文本框中输入oe,就能看到想要的结果。  

再搞一个,加深印象。