1

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>
4

0 に答える 0