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 rel="nofollow noopener noreferrer" 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。

到此这篇关于asp.net+ajax+sqlserver自动补全功能实现解析就介绍到这了。积极思考造成积极人生,消极思考造成消极人生。更多相关asp.net+ajax+sqlserver自动补全功能实现解析内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!

您可能有感兴趣的文章
ASP.NET中Response.BufferOutput属性的使用技巧

ASP.NET轻量级MVC框架Nancy的基本用法

ASP.NET Core中的对象池介绍

.NET集成ORM框架HiSql

asp.net中MVC的处理流程详解