asp.net+ajax+sqlserver自动补全功能实现解析
程序员文章站
2024-02-26 17:53:46
代码下载 说明:数据库连接字符串在web.config文件中,为方便运行使用的是官方的northwind数据库。 参考(向其作者致敬): ² http://www...
代码下载
说明:数据库连接字符串在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。
说明:数据库连接字符串在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。
下一篇: 12、文件上传