c# - UpdatePanel、ModalPopupExtender 和输入按键问题

标签 c# asp.net webforms updatepanel modalpopupextender

有一个包含 2 个面板的 UpdatePanel,其中默认按钮设置为监听输入按键。 UpdatePanel 是 ModalPopupExtender 的 PopupControl。

在整个页面回发的模态弹出窗口中按 enter 时遇到问题。有任何想法吗?以下是一些代码片段(我已经删除了无关的字段...):

<div runat="server" id="divShippingEstimatorPopup" class="shippingEstimatorModalPopup">
<asp:UpdatePanel ID="upPopup" runat="server">
    <ContentTemplate>
        <asp:Panel runat="server" ID="pnlShippingEstimator" DefaultButton="lnkbtnGetEstimates">
            <div class="title content_title">Shipping Estimator</div>
            <asp:Label runat="server" ID="lblMessage" />
            <table cellpadding="0" cellpadding="0" class="shipping">
                <!-- Removed to shorten code snippet -->
                <tr>
                    <td colspan="2">
                        <div class="buttonHolder">                            
                            <Monarch:LinkButtonDefault runat="server" ID="lnkbtnGetEstimates" CssClass="button_action button_margin_right" CausesValidation="false">Get Estimates</Monarch:LinkButtonDefault>
                            <asp:LinkButton runat="server" ID="lnkbtnCancel" CssClass="button_secondary button_secondary_fixed" CausesValidation="false">Cancel</asp:LinkButton>
                            <div class="clear"></div>
                        </div>
                        <div class="clear"></div>
                    </td>
                </tr>
            </table>
        </asp:Panel>
        <asp:Panel runat="server" ID="pnlShippingOptions" DefaultButton="lnkbtnSetEstimate">
            <div class="shippingOptionsHolder" runat="server" id="divShippingOptionsHolder">
                <!-- Removed to shorten code snippet -->
                <div class="buttonHolder">
                    <Monarch:LinkButtonDefault runat="server" ID="lnkbtnSetEstimate" CssClass="button_action">Set Estimate</Monarch:LinkButtonDefault>
                    <div class="clear"></div>
                </div>
                <div class="clear"></div>
            </div>
        </asp:Panel>
    </ContentTemplate>
</asp:UpdatePanel>

请记住 LinkBut​​tonDefault 就是这样的:

public class LinkButtonDefault : LinkButton
{
    private const string AddClickScript = "SparkPlugs.FixLinkButton('{0}');";

    protected override void OnLoad(EventArgs e)
    {
        string script = String.Format(AddClickScript, ClientID);
        Page.ClientScript.RegisterStartupScript(GetType(), "click_" + ClientID,
            script, true);
        base.OnLoad(e);
    }
}

最后,这里是控件的其余部分:

<asp:UpdatePanel runat="server" ID="upGetEstimate">
    <ContentTemplate>
        <asp:LinkButton runat="server" ID="lnkbtnGetEstimate" CausesValidation="false">Get Estimate</asp:LinkButton>
    </ContentTemplate>
</asp:UpdatePanel>

<ajaxToolKit:ModalPopupExtender ID="shippingEstimatorPopupExtender" runat="server" TargetControlID="lnkbtnFake" PopupControlID="divShippingEstimatorPopup" BackgroundCssClass="monarchModalBackground"></ajaxToolKit:ModalPopupExtender>
<asp:LinkButton runat="server" ID="lnkbtnFake" style="display:none;"/>

<Monarch:PopupProgress ID="popupProgressGetEstimate" runat="server" AssociatedUpdatePanelId="upGetEstimate" />
<Monarch:PopupProgress ID="popupProgressGetEstimates" runat="server" AssociatedUpdatePanelId="upPopup" />

基本上,用户单击“获取估算”,加载表单时会出现一个进度条,表单显示在模态弹出窗口中。我猜这很简单,但我不能只得到正确的组合来让它正常工作。

最佳答案

首先尝试使用脚本管理器在后面的代码中注册脚本会发生什么情况。

我使用这种方法注册脚本:

public static void RegisterStartupScript(Control c, string script)
{
    if ((ToolkitScriptManager.GetCurrent(c.Page) as ToolkitScriptManager).IsInAsyncPostBack)
        ToolkitScriptManager.RegisterStartupScript(c, c.GetType(), "Script_" + c.ClientID.ToString(), script, true);
    else
        c.Page.ClientScript.RegisterStartupScript(c.GetType(), c.ClientID, script, true);
}

这会检查您的页面中是否有 ScriptManager。如果没有,它会使用完整的回发版本。

关于c# - UpdatePanel、ModalPopupExtender 和输入按键问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7264218/

相关文章:

c# - 在填充到数据表之前将所有 excel 列格式化为常规

asp.net - 如何在 Entity Framework Core 2.1 中播种枚举

c# - 使用安装在 IIS 上的 URL Rewrite 配置 Web API

c# - 如何在不依赖于实现的情况下使用接口(interface)的实现?

c# - 如何计算 C# 中的类属性?

c# - 合并键值对列表

c# - 使用 Active Directory 连接到 Azure DB - 通用,并在 C# 中使用 MFA 支持身份验证

c# - 防止 SQL 重复预订

c# - Wcf事务

asp.net - 发布到 Azure 失败,出现 500 内部服务器错误