响应<input />字段中的“enter”按键

时间:2012-07-30 05:05:04

标签: c# javascript jquery asp.net html

我的问题是关于处理Enter键按下。我有一个名为“order.aspx”的页面,它位于母版页内。我在解释控制结构

1. <asp:TextBox ID="txtSearch" MaxLength="50" runat="server" Width="420px" CssClass="txtbox"></asp:TextBox>

2. <asp:Button ID="btnSearch" runat="server" OnClick="btnSearch_Click" />

3. one asp grid control with one column containing textbox for entering order quantity 

4. <asp:Button ID="btnOrder" runat="server" OnClick="btnOrder_Click" />.

我的要求是,

  1. 当用户在搜索文本框中输入文本并按回车键然后btnSearch_Click应该触发
  2. 当用户在网格文本框中输入数量并按回车键然后btnOrder_Click应该触发。
  3. 我试过不同的代码终于得到了答案,但它没有完全正常.Follwing是我用过的javascript代码。

    function DoEnterKeyButtonClick(buttonId) {
         e = event;
         var code = (e.keyCode ? e.keyCode : e.which);
         if (code == 13) {
             document.getElementById('ctl00_CphMaster_' + buttonId).click();
             return false;
         }
    }
    

    我在按下txtSearch和网格文本框时调用此方法,并将Button id分别传递给fire事件btnSearch和btnOrder。当我在搜索文本框中输入文本并按下回车键时,btnSearch_Click正在触发,当我正在输入订单数量并按下回车键btnOrder_Click正在解雇。但问题是,在更改页面索引后说第二页所需的功能不起作用。那就是当我输入订单数量并点击回车键然后btnSearch_Click将首先开火,然后btnOrder_Click开火。这将清除输入的数量并导致错误。请帮助我......

    谢谢, JOBY

3 个答案:

答案 0 :(得分:5)

而不是提供此document.getElementById('ctl00_CphMaster_' + btnSearch).click();

试试这个document.getElementById('<%= btnSearch.ClientID %>').click();

或尝试使用jquery

$("#txtSearch").keyup(function(event){
    if(event.keyCode == 13){
        $("#btnSearch").click();
    }
});

否则将控件放在asp:面板中,并将DefaultButton属性设置为btnSearch,如下所示

<asp:Panel ID="Panel1" runat="server" DefaultButton="btnSearch">
    <asp:TextBox ID="txtSearch" MaxLength="50" runat="server" Width="420px" CssClass="txtbox"></asp:TextBox>
    <asp:Button ID="btnSearch" runat="server" OnClick="btnSearch_Click" />
    </asp:Panel>

希望这会有所帮助。

非常感谢 安娜

答案 1 :(得分:1)

你的功能不知道究竟是什么。 试试这个

function DoEnterKeyButtonClick(event,buttonId){}

答案 2 :(得分:1)

我保留了以下方便的片段..

function getIntKey(key) {
    var keycode;
    if (key == null) { keycode = event.keyCode; } else { keycode = key.keyCode; }
    return keycode;
}

并使用它,就像这样..

$("#txtSearch").keyup(function(e){
  if(getIntKey(e) == 13){
     //Enter was pressed, do somthing
  }
});