程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> asp.net+ajax+sqlserver自動補全功能實現解析

asp.net+ajax+sqlserver自動補全功能實現解析

編輯:ASP.NET基礎
代碼下載

說明:數據庫連接字符串在web.config文件中,為方便運行使用的是官方的Northwind數據庫。

參考(向其作者致敬):

² http://www.loveweb8.com/plus/demo.php?aid=57這個例子是html源碼。利用jquery.autocomplete插件利用js實現了自動補全功能。由於我的需要是結合sqlserver數據庫表實現自動補全功能。就下來就是將數據庫表轉為js數組,自然而然就想到了ajax。

² Asp.NetAjax的兩種基本開發模式這篇文章中的第二部分就是說:js調用webservice的示例。

代碼解析。

1.添加webservice文件。

添加新項--“啟用了AJAX的WCF服務” 將新文件命名為DBService.svc.

2.在DBService.svc中添加函數,函數返回值就是 提示自動補全的數據。
復制代碼 代碼如下:
[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 ())函數中調用webservice獲取自動補全的數據,並將數據關聯到輸入框中。
復制代碼 代碼如下:
<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。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved