javascript - 为什么 WebForms 不断呈现这个 data- 属性?

标签 javascript c# jquery asp.net webforms

WebForms 不断重新渲染带有 data- 属性的 TextBox 控件,尽管我的代码在 PostBack 上删除了它 - 我不应该这样做首先,因为回发过程会清除属性。我尝试清除 OnInitOnUnload 中的属性,但它们在留下代码隐藏后以某种方式重新出现。它们仅曾经通过 TextChanged 事件重置。

我正在疯狂地试图弄清楚我的 web.config 中是否有一个缓存设置会阻止 ASP.NET 正确删除此属性。

作为引用,(据我所知)我的代码的相关部分:

.aspx JavaScript:

$("[data-confirm]").each(function () {
    var alertText = $(this).attr("<%= _data_confirm %>");

    $(alertText).dialog({
        modal: true,
        draggable: false,
        resizable: false,
        closeOnEscape: false,
        title: "Note",
        width: 330,
        buttons: {
            "Continue with Application": function () {
                $(this).dialog("close");
            }
        }
    });
});

.aspx.cs C#:

protected override void OnInit(EventArgs e)
{
    if (Page.IsPostBack)
    {
        ClearIraDistributionConfirmation();
    }

    iraDistribution.TextChanged += iraDistribution_TextChanged;
}

void iraDistribution_TextChanged(object sender, EventArgs e)
{
    if (SessionFormData.ConfirmedIraDistribution == false
        && SessionFormData.IraDistribution.HasValue
        && SessionFormData.IraDistribution.Value > 0)
    {
        iraDistribution.Attributes[_data_confirm] =
            "<div>You must submit a copy of the first page of your 2014 federal tax return to verify the rollover amount.</div>";
        iraDistribution.Attributes[_aria_live] = "assertive";
        SessionFormData.ConfirmedIraDistribution = true;
    }
    else if (SessionFormData.ConfirmedIraDistribution)
    {
        ClearIraDistributionConfirmation();
    }
}


private void ClearIraDistributionConfirmation()
{
    if (SessionFormData.ConfirmedIraDistribution)
    {
        iraDistribution.Attributes.Clear();
    }
}

我已经验证,在回发周期结束时,iraDistribution 没有设置任何属性。一旦我的 .aspx JS 到达 JavaScript 的第一行(也就是我粘贴到此处的 JS 之前),iraDistribution 就会设置其 data-confirm 属性。

我错过了什么?

最佳答案

这个问题的答案是:页面生命周期。

我尝试在 OnInit 中检查 TextBox 值时犯了一个错误,当时它们还不可用。 OnUnload 也不起作用,因为此时值已经呈现为输出。

我通过重新排序上面的代码并将其移至 OnLoadComplete 事件中修复了此错误。我的代码现在看起来像(嗯——不太像这样,但它被缩写为删除与 session 交互的代码、我定义的用于提高可读性的函数等):

protected override void OnLoadComplete(EventArgs e)
{
    base.OnLoadComplete(e);

    if (SessionFormData.ConfirmedIraDistribution)
    {
        iraDistribution.Attributes.Clear();
    }
    else if (SessionFormData.ConfirmedIraDistribution == false
        && SessionFormData.IraDistribution.HasValue
        && SessionFormData.IraDistribution.Value > 0)
    {
        iraDistribution.Attributes[_data_confirm] =
            "<div>You must submit a copy of the first page of your 2014 federal tax return to verify the rollover amount.</div>";
        iraDistribution.Attributes[_aria_live] = "assertive";
        SessionFormData.ConfirmedIraDistribution = true;
    }
}

这个故事的寓意:页面生命周期会吃掉你的午餐。

关于javascript - 为什么 WebForms 不断呈现这个 data- 属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28991986/

相关文章:

javascript - 如何在菜单项中显示内联图标?

javascript - 尝试在纯 JS 中获取元素的渲染高度时元素为 null

javascript - js 并在加载前编辑 url - 如何执行此操作

javascript - 带有 null 值的 AngularJS ngRepeat 过滤器会永久删除 null,为什么?

javascript - 等待结果的调用方法 - 中间值尚未解析

c# - 在windows服务中传递参数

c# - 如果分配了相同的值,setter 是否应该立即返回?

c# - 如何证明释放了弱引用?

jquery - 使用 JQuery 根据属性数组更改 css

javascript - 复选框启用 onload 以显示其他元素