Panel Default Button属性如何工作?

时间:2013-07-02 21:15:52

标签: javascript asp.net viewstate

当您在ASP.NET Button中声明DefaultButton用作Panel时,会发生什么?我知道ASP.NET会将Panel的内容呈现为div并将一堆内容传递给ViewState。 ViewState中是否有处理渲染Button的click事件的JavaScript?我认为ViewState就是那个 - 有关状态的信息。它是如何工作的?

1 个答案:

答案 0 :(得分:12)

您对ViewState的看法正确。它旨在保持页面和控件的值。也就是说,他们的。您可以确认here

关于默认按钮,没有魔法。将{j}添加到div以绑定ENTER键事件。

让我们看看吧!这段代码:

<asp:Panel ID="panel" runat="server" DefaultButton="button">
    <asp:Button ID="button" runat="server" Text="this is the button" />
</asp:Panel>

渲染到:

<div id="panel" onkeypress="javascript:return WebForm_FireDefaultButton(event, 'button')">
  <input type="submit" name="button" value="this is the button" id="button">          
</div>

这个javascript是由WebForms引擎生成的,但如果您有点好奇,我们可以查找它:

function WebForm_FireDefaultButton(event, target) {
    if (event.keyCode == 13) {
        var src = event.srcElement || event.target;
        if (!src || (src.tagName.toLowerCase() != "textarea")) {
            var defaultButton;
            if (__nonMSDOMBrowser) {
               defaultButton = document.getElementById(target);
            }
            else {
                defaultButton = document.all[target];
            }
            if (defaultButton && typeof(defaultButton.click) != "undefined") {
                defaultButton.click();
                event.cancelBubble = true;
                if (event.stopPropagation) event.stopPropagation();
                return false;
            }
        }
    }
    return true;
}

注意它如何测试当前聚焦的控件是否为textarea。这是因为textarea内的ENTER主要是新行,而不是提交。