AjaxControlToolkit Autocompleteextender(ToolkitScriptManagerを備えたVisual Studio 2008の場合)を使用して、データベースから返される値を提案しようとしています。単純な文字列配列を返す場合、正常に機能しています。しかし、データベースからデータをプルしようとすると、機能しません。以下は私のWebサービスコードとAutocompleteextenderHtmlです。ブレークポイントなしで以下を実行している場合、エラーはスローされませんが、機能しません。また、ブレークポイントを設定すると、JavaScriptエラー「MicrosoftJScriptランタイムエラー:Sys.ParameterCountException:パラメーターカウントの不一致」が発生します。
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
[ScriptService]
public class AutoComplete : System.Web.Services.WebService
{
[WebMethod]
[ScriptMethod]
public string[] GetAgentCompanyAutoCompleteList(string prefixText, int count, string contextKey)
{
//return new string[] { "aaaaaaa", "bbbbbb" };
string sql = string.Format("select distinct AgentCompany from Realtors where FK_CompanyID = {0} Order By AgentCompany", contextKey);
string[] items = new string[] { "" };
string cn = "Data Source=localhost;Initial Catalog=ABCD;Integrated Security=True";
using (SqlDataAdapter da = new SqlDataAdapter(sql, cn))
{
DataTable dt = new DataTable();
da.Fill(dt);
if (dt != null && dt.Rows.Count > 0)
for (int i = 0; i < dt.Rows.Count; i++)
items[i] = dt.Rows[i]["AgentCompany"].ToString();
}
return items;
}
}
<asp:TextBox ID="txtCompany" runat="server" MaxLength="256" Width="150px">/asp:TextBox>
<ajax:AutoCompleteExtender
ID="AutoCompleteExtender1"
runat="server"
EnableCaching="true"
MinimumPrefixLength="1"
TargetControlID="txtCompany"
ServicePath="~/AutoComplete.asmx"
ServiceMethod="GetAgentCompanyAutoCompleteList"
UseContextKey="true">
</ajax:AutoCompleteExtender>