asp.net+ajax+sqlserver自動(dòng)補(bǔ)全功能實(shí)現(xiàn)解析
更新時(shí)間:2014年03月05日 16:42:47 作者:
這篇文章主要介紹了asp.net + ajax + sqlserver 自動(dòng)補(bǔ)全功能,需要的朋友可以參考下
代碼下載
說明:數(shù)據(jù)庫連接字符串在web.config文件中,為方便運(yùn)行使用的是官方的Northwind數(shù)據(jù)庫。
參考(向其作者致敬):
² http://www.loveweb8.com/plus/demo.php?aid=57這個(gè)例子是html源碼。利用jquery.autocomplete插件利用js實(shí)現(xiàn)了自動(dòng)補(bǔ)全功能。由于我的需要是結(jié)合sqlserver數(shù)據(jù)庫表實(shí)現(xiàn)自動(dòng)補(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ù)返回值就是 提示自動(dòng)補(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獲取自動(dòng)補(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("出錯(cuò)了!");
}
});
</script>
5.Finish。
說明:數(shù)據(jù)庫連接字符串在web.config文件中,為方便運(yùn)行使用的是官方的Northwind數(shù)據(jù)庫。
參考(向其作者致敬):
² http://www.loveweb8.com/plus/demo.php?aid=57這個(gè)例子是html源碼。利用jquery.autocomplete插件利用js實(shí)現(xiàn)了自動(dòng)補(bǔ)全功能。由于我的需要是結(jié)合sqlserver數(shù)據(jù)庫表實(shí)現(xiàn)自動(dòng)補(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ù)返回值就是 提示自動(dòng)補(bǔ)全的數(shù)據(jù)。
復(fù)制代碼 代碼如下:
[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文件:
復(fù)制代碼 代碼如下:
<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獲取自動(dòng)補(bǔ)全的數(shù)據(jù),并將數(shù)據(jù)關(guān)聯(lián)到輸入框中。
復(fù)制代碼 代碼如下:
<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("出錯(cuò)了!");
}
});
</script>
5.Finish。
相關(guān)文章
asp.net導(dǎo)出excel數(shù)據(jù)的常見方法匯總
這篇文章主要介紹了asp.net導(dǎo)出excel數(shù)據(jù)的常見方法,實(shí)例匯總了數(shù)據(jù)導(dǎo)出的常見的方法以及相關(guān)的注意事項(xiàng),是非常實(shí)用的技巧,需要的朋友可以參考下2014-10-10在asp.net下實(shí)現(xiàn)Option條目中填充前導(dǎo)空格的方法
在asp.net下實(shí)現(xiàn)Option條目中填充前導(dǎo)空格的方法...2007-03-03Global.asax取物理路徑/取絕對(duì)路徑具體方法
本文章來給大家簡單介紹利用Global.asax取物理路徑和取絕對(duì)路徑代碼,有需要了解的朋友可參考參考2013-08-08asp.net實(shí)現(xiàn)三層架構(gòu)的例子
這篇文章主要介紹了asp.net實(shí)現(xiàn)三層架構(gòu)的例子,十分的簡單實(shí)用,有需要的小伙伴可以參考下。2015-07-07.net數(shù)據(jù)庫連接池配置技巧(默認(rèn)值)
ado.net 本就有連接功能,所有.net開法基本不用去考慮連接問題,怪不得.net的連接池資料網(wǎng)上找不到。.net連接池只要在連接字符串里配制就可以了2008-12-12使用ASP.NET 2.0 CSS 控件適配器生成CSS友好的HTML輸出
使用ASP.NET 2.0 CSS 控件適配器生成CSS友好的HTML輸出...2007-03-03如何在?ASP.NET?Core?Web?API?中處理?Patch?請(qǐng)求
這篇文章主要介紹了在?ASP.NET?Core?Web?API中處理Patch請(qǐng)求,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05