0

我在 ASP.NET/C# 中使用 AutoCompleteExtender 从我的数据库中检索数据,以及该字段的主键。选择名称后,即使在单击提交之前,也会检索详细信息(名称/pk),然后将这些信息传递到隐藏字段。

我遇到的问题是,如果用户输入的名称不正确,pk 将不会重置,并且与之前的搜索保持相同 - 这意味着当用户单击搜索时,将显示旧数据。

这是我的自动完成服务:

 public string[] GetAutoComplete(string prefixText, int count)
    {

        string connection = ConfigurationManager.ConnectionStrings["TestConnectionString"].ConnectionString;
        string sql = "SELECT * FROM SageAccount WHERE Name LIKE @prefixText AND Customer = 1 AND SageID IS NOT NULL";
        SqlDataAdapter da = new SqlDataAdapter(sql, connection);
        da.SelectCommand.Parameters.Add("@prefixText", SqlDbType.VarChar, 50).Value = prefixText + "%";
        DataTable dt = new DataTable();
        da.Fill(dt);
        List<string> Names = new List<string>();
        foreach (DataRow dr in dt.Rows)
        {
            Names.Add(AjaxControlToolkit.AutoCompleteExtender.CreateAutoCompleteItem(dr["Name"].ToString() + " (" + dr["SageID"].ToString() + ")", dr["ID"].ToString()));
        }

        return Names.ToArray();

    }

用于填充隐藏字段的 JavaScript 是:

function autoCompleteItemSelected(source, eventArgs) {
            var assocHiddenField = document.getElementById(source.get_id() + '_hidden');
            assocHiddenField.value = eventArgs.get_value();
        }

如果没有返回结果,重置隐藏字段的最佳方法是什么?我目前确实有一个“部分工作”的解决方案,这是一段 JavaScript:

   function pageLoad() {

    $find('txtName')._onMethodComplete = function(result, context) {


        $find('txtName')._update(context, result, false);
        webservice_callback(result, context);
    };


}
function webservice_callback(result, context) {
    var hiddenfield = document.getElementById('txtName_hidden');
    if (result == "")
        hiddenfield.value = '0';
}

但是如果用户非常快速地点击输入/点击提交,它不会重置。如果他们没有点击一两秒钟,它就会起作用,并将隐藏字段重置为 0。

大家还有什么想法吗?

4

2 回答 2

5

您可以将 AJAX 自动完成扩展器的 OnClientPopulating 属性设置为清除隐藏字段的 JS。

function ClearHidden(source, eventArgs) {
        document.getElementById('<%=this.hdnUsrIdSel.ClientID%>').value = null;
}

<ajaxToolkit:AutoCompleteExtender ID="autoCompleteExtend" runat="server" 
        MinimumPrefixLength="1" ServiceMethod="GetCompletionList" 
        FirstRowSelected="true" 
        ServicePath="~/WebServices/Autocomplete.asmx" TargetControlID="txtUsers" 
        UseContextKey="True" CompletionSetCount ="10" 
        OnClientPopulating="ClearHidden" 
于 2012-02-20T07:23:39.150 回答
0

尝试使用$addHandler附加到文本框的按键事件。清除该事件处理程序中的隐藏字段:

$addHandler($get("txtName"), "keypress", function(e) {
    $get("txtName_hidden").value = "";
}, true);
于 2010-10-28T10:46:44.760 回答