asp.net+ajax+sqlserver自动补全功能实现解析

代码下载

说明:数据库连接字符串在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。

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 &#39;EastRiver&#39; 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...