asp.net+ajax+sqlserver自動補(bǔ)全功能實(shí)現(xiàn)解析

字號:


    這篇文章主要介紹了asp.net + ajax + sqlserver 自動補(bǔ)全功能,需要的朋友可以參考下
    代碼下載
    說明:數(shù)據(jù)庫連接字符串在web.config文件中,為方便運(yùn)行使用的是官方的Northwind數(shù)據(jù)庫。
    參考(向其作者致敬):
    ² http://www.loveweb8.com/plus/demo.php?aid=57這個例子是html源碼。利用jquery.autocomplete插件利用js實(shí)現(xiàn)了自動補(bǔ)全功能。由于我的需要是結(jié)合sqlserver數(shù)據(jù)庫表實(shí)現(xiàn)自動補(bǔ)全功能。就下來就是將數(shù)據(jù)庫表轉(zhuǎn)為js數(shù)組,自然而然就想到了ajax。
    ² Asp.NetAjax的兩種基本開發(fā)模式這篇文章中的第二部分就是說:js調(diào)用webservice的示例。
    代碼解析。
    1.添加webservice文件。
    添加新項(xiàng)--“啟用了AJAX的WCF服務(wù)” 將新文件命名為DBService.svc.
    2.在DBService.svc中添加函數(shù),函數(shù)返回值就是 提示自動補(bǔ)全的數(shù)據(jù)。
    代碼如下:
    [OperationContract]
    public string getSortList()
    {
    List<string> sorts = new List<string>();
    using (SqlConnection cn = new SqlConnection(ConfigurationManager.ConnectionStrings["zhui.pc"].ConnectionString))
    {
    cn.Open();
    SqlCommand cmd = new SqlCommand("select [LastName] from [dbo].[Employees]", cn);
    DataTable dt = new DataTable();
    using (SqlDataAdapter da = new SqlDataAdapter(cmd))
    {
    da.Fill(dt);
    }
    foreach (DataRow row in dt.Rows)
    {
    sorts.Add(row[0].ToString());
    }
    cn.Close();
    }
    return string.Join(",", sorts.ToArray());
    }
    3.在default.aspx文件添加js、css文件:
    代碼如下:
    <script src="Scripts/jquery-1.7.1.min.js" type="text/javascript"></script>
    <script src="Scripts/jquery.autocomplete.min.js" type="text/javascript"></script>
    <link href="Styles/jquery.autocomplete.css" rel="stylesheet" type="text/css" />
    4.在default.aspx的head部分中$().ready(function ())函數(shù)中調(diào)用webservice獲取自動補(bǔ)全的數(shù)據(jù),并將數(shù)據(jù)關(guān)聯(lián)到輸入框中。
    代碼如下:
    <script type="text/javascript">
    $().ready(function () {
    NewsSort.getSortList(OnComplete, OnFailed, null);
    function OnComplete(args, context) {
    $('#MainContent_searchBox').AutoComplete({
    'data': args.split(","),
    'itemHeight': 20,
    'listDirection': 'down',
    'width': 280
    }).AutoComplete('show');
    }
    function OnFailed(args) {
    alert("出錯了!");
    }
    });
    </script>
    5.Finish。