繁体   English   中英

按Enter键时自动完成扩展器ajax

[英]Autocomplete Extender ajax on pressing enter key

我在网页上创建了Ajax自动完成扩展器,该扩展器从数据库中检索值。 当我从自动完成下拉列表中选择一个选项时,我得到了期望的结果。 问题是:

当用户自己输入整个单词(或粘贴单词)且未从下拉列表中选择选项之一并按Enter时,结果为空白。 我该如何解决这个问题?

我的自动完成扩展程序代码是:

<asp:HiddenField ID="HiddenID" runat="server" />
            <asp:ToolkitScriptManager ID="ToolkitScriptManager1" runat="server">
            </asp:ToolkitScriptManager>
            <asp:TextBox ID="SearchRetailer" runat="server" Style="background-image: url(Search-icon.png ); border: 1px groove black; background-position: right; background-repeat: no-repeat; float: right; width: 20%;" />
            <asp:AutoCompleteExtender
                ID="AutoCompleteExtender1"
                TargetControlID="tgt1"
                runat="server" MinimumPrefixLength="2" ServiceMethod="GetCompletionList" UseContextKey="True" OnClientItemSelected="GetCode" EnableCaching="true" />

javascript函数是:

  <script type="text/javascript" language="javascript">

    function GetCode(source, eventArgs) {
        var hfield = $get('<%=this.HiddenID.ClientID%>');
        hfield.value = eventArgs.get_value();
        window.open("newPage.aspx?Paramter1=" + hfield.value + "", "_self", false);
    }

</script>

我的网络服务代码是:

 [System.Web.Services.WebMethodAttribute(), System.Web.Script.Services.ScriptMethodAttribute()]
public static string[] GetCompletionList(string prefixText, int count, string contextKey)
{

    SqlConnection sqlconn = "my connection string"

    string sql = "select abc from aaa where abc like '" + prefixText + "%'";
    SqlDataAdapter cmd1 = new SqlDataAdapter(sql, sqlconn);
    DataTable dt0r = new DataTable();
    cmd1.Fill(dt0r);
    int i = 0;
    string[] rList = new string[dt0r.Rows.Count];        
    foreach (DataRow dr in dt0r.Rows)
    {
        rList.SetValue(dr["abc"].ToString(), i);

        i++;
    }
    return rList;

}

我知道了。

我在自动完成扩展器的属性中添加了FirstRowSelected =“ true”,该功能现在可以正常使用了!!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM