asp.net + ajax + sqlserver 自动补全功能

代码下载页面:http://download.csdn.net/detail/zhanghui_hn/6994105

说明:数据库连接字符串在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。项目发布后如果提示webservice找不到对象,请参考了http://www.cnblogs.com/aspnethot/articles/2421678.html



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值