1

这是我的 .aspx 页面中的代码,我正在为文本框使用自动完成功能。

<script type="text/javascript">
    $(document).ready(function () {
        SearchText();
    });
    function SearchText() {
        $(".autosuggest").autocomplete({
            source: function (request, response) {
                $.ajax({
                    type: "POST",
                    contentType: "application/json; charset=utf-8",
                    url: "Preferences.aspx/GetAutoCompleteData",
                    data: "{'Name':'" + document.getElementById('txtSearch').value + "'}",
                    dataType: "json",
                    success: function (data) {
                        response(data.d);
                    },
                    error: function (result) {
                        alert("Error");
                    }
                });
            }
        });
    }
</script>


<table style="width:auto">
    <tr>
        <td>
            <asp:Label ID="Label1" runat="server" Text="Please Type Student Name:"></asp:Label>
        </td>
        <td>
            <input type="text" id="txtSearch" class="autosuggest" />
            <asp:TextBox ID="TextBox1" runat="server" Text=txtsearch Visible="true" class="autosuggest"></asp:TextBox>
        </td>
        <td>
            <asp:Button ID="btnAdd" runat="server" Text="Add" OnClick="btnAdd_Click" />
        </td>
    </tr>
</table>

如果我把 runat="Server" 在

<input type="text" id="txtSearch" class="autosuggest" />

然后自动完成不起作用。表单标签用于母版页。

使用控件的名称属性解决的问题

源代码:

    <input type="text" name="_name"  />

    <asp:Button ID="btnShow" runat="server" Text="Show" onclick="btnShow_Click" />

代码隐藏:

protected void btnShow_Click(object sender, EventArgs e)
 {
    string strValue = Page.Request.Form["_name"].ToString();
    Response.Write(strValue);
 }

参考:http ://www.etechpulse.com/2013/02/get-html-input-controls-value-server.html

谢谢大家帮助。

4

2 回答 2

2

如果您使用 MasterPage,则 ASP.net 将为每个控件自动生成一个名称并将其附加到您的控件中,为了获得您需要使用 JQuery ClientID 的控件的唯一 ID。

runat="server"您的 jquery 函数更改为(这将通过 ClientID 检索输入):

 function SearchText() {
        $("#<%=txtSearch.ClientID%>").autocomplete({

或者作为替代方案(由 DeeMac 建议)使用静态ClientIDMode

于 2013-10-08T09:09:28.483 回答
0

要获取值表单文本框,您需要使用服务器控件。

 <asp:TextBox ID="txtSearch" runat="server" ></asp:TextBox>

您还可以在服务器控件中添加ClientIDMode="static"以保持您的 id 完全相同,或者您可以使用它 $("#<%=txtSearch.ClientID%>")来获取动态生成的 Id。

于 2013-10-08T09:43:00.683 回答