AjaxControlToolkit AutoCompleteExtender控件演示

前端之家收集整理的这篇文章主要介绍了AjaxControlToolkit AutoCompleteExtender控件演示前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

原本程序是一个查询文本框,现用户要求改程序,要如google或baidu输入一样,有自动完成功能。下图是已经完成的效果

实现使用了Web Service技术与Ajax的AutoCompleteExtender的控件。在数据库中,写好存储过程:

CREATE PROCEDURE [ dbo ] . [ usp_Fqa_LotNumberCompletionList ]
(
@PrefixText NVARCHAR ( 4000 ),
@TopCount INT
)
AS
DECLARE @W NVARCHAR ( 4000 ) = @PrefixText + ' % '
EXECUTE ( ' SELECTTOP ' + @TopCount + ' [LotNumber]FROM[dbo].[Fqa]WHERE[IsSubmit]=1AND[LotNumber]LIKE ''' + @w + '''' )

创建一个Web Service,执行存储过程:

using System;
using System.Collections;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Services;

/// <summary>
/// SummarydescriptionforFqaLotNumberService
/// </summary>
namespace Insus.NET
{
[WebService(Description
= " FqaLotNumberService " ,Name = " FqaLotNumberService " ,Namespace = http://xxx.xxx.com/WebServices/ )]

[WebServiceBinding(ConformsTo
= WsiProfiles.BasicProfile1_1)]
// ToallowthisWebServicetobecalledfromscript,usingASP.NETAJAX,uncommentthefollowingline.
[System.Web.Script.Services.ScriptService]
public class FqaLotNumberService:System.Web.Services.WebService
{
BusinessBaSEObjBusinessBase
= new BusinessBase();

public FqaLotNumberService()
{
// Uncommentthefollowinglineifusingdesignedcomponents
// InitializeComponent();
}

[WebMethod]
public string []GetFqaLotNumber( string prefixText, int count)
{
Parameter[]parameter
= {
new Parameter( " @PrefixText " ,sqlDbType.NVarChar, 4000 ,prefixText),
new Parameter( " @TopCount " ,sqlDbType.Int, 4 ,count)
};
DataTableLotNumberTable
= objBusinessBase.GetDataToDataSet( " usp_Fqa_LotNumberCompletionList " ,parameter).Tables[ 0 ];

ArrayListarray
= new ArrayList();
foreach (DataRowdataRow in LotNumberTable.Rows)
{
array.Add(dataRow[
" LotNumber " ].ToString());
}

return ( string [])array.ToArray( typeof ( string ));
}
}
}


上面的Web Service中,你会看到一个类别BusinessBase,可以从下面地址下载:http://www.cnblogs.com/insus/articles/1654653.html

.aspx:

批号: < asp:TextBox ID ="txtLotNumber" runat ="server" ></ asp:TextBox > &nbsp;&nbsp;
< asp:Button ID ="ButtonSearch" runat ="server" OnClick ="ButtonSearch_Cliek" Text ="Search" />
< ajaxToolkit:AutoCompleteExtender ID ="AutoCompleteExtender1" runat ="server" MinimumPrefixLength ="1"
TargetControlID
="txtLotNumber" ServiceMethod ="GetFqaLotNumber" ServicePath ="~/WebServices/FqaLotNumberService.asmx"
CompletionSetCount
="10" >
</ ajaxToolkit:AutoCompleteExtender >


实现过程中,Ajax AutoCompleteExtender控件,只能使用本域的Service,不能跨域,此问题Insus.NET花上不少时间测试。原本Service是摆放在一个单独的WebService的站点上的,取不到数据,只能把Service移至本站点中来。

猜你在找的Ajax相关文章