2

我正在尝试解决在更新面板中使用内联脚本的问题。这个问题通常可以通过使用 Sys.Application.add_load() 或使用 ScriptManager 创建 RegisterStatupScript() 脚本来解决。但是,在这种情况下,这两种解决方案都不起作用。

这是问题所在。

asp.net(在本例中为 SharePoint)页面上的更新面板:

<asp:UpdatePanel ID="UpdatePanel1" UpdateMode="Conditional" runat="server">
    <ContentTemplate>
        <asp:Button ID="Button1" runat="server" Text="Load" />
        <asp:PlaceHolder ID="PlaceHolder1" runat="server"></asp:PlaceHolder>
    </ContentTemplate>
</asp:UpdatePanel>

假设在后面的代码中,我们在单击按钮时将用户控件添加到占位符。

protected void Button1_Click(object sender, EventArgs e)
{
    MyControl ctrl = new MyControl();
    PlaceHolder1.Controls.Clear();
    PlaceHolder1.Controls.Add(ctrl);

    UpdatePanel1.Update();
}

最后,假设我们的用户控件有一些内联脚本。

<script type="text/javascript">
    var myInt = 1;
    alert(typeof myInt);
</script>

将上述内容放在一起并运行它会导致默认情况下为空的更新面板(按钮除外) - 获取单击按钮时添加的一些数据,类似于上面的 javascript。问题是上面的 javascript 代码永远不会触发

在我的现实生活中,用户控件并不是非常复杂——它有一个转发器,在加载控件时填充,然后是一些内联 javascript,它会稍微转换转发器数据。数据通过,但 javascript 永远不会执行并且不会引发错误。

尝试的解决方案:将内联 javascript 包装在一个名为 initMyCode() 的函数中,然后使用:

ScriptManager.RegisterStartupScript(this, this.getType(), UniqueID, "initMyCode()", true);

...在用户控制页面加载事件上。这会失败,因为在页面中找不到 initMyCode()。

有人对此问题有可行的解决方案吗?

4

2 回答 2

1
if(!Page.ClientScript.IsStartupScriptRegistered("initMyCode")){ 
 string script =@"function initMyCode(){var myInt = 1;
   alert(typeof myInt);}
 Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(initMyCode);"
 ScriptManager.RegisterStartupScript(this, this.getType(), initMyCode, script, true);

}

或者

<script type="text/javascript">
 function initMyCode(){
 var myInt = 1;
 alert(typeof myInt);}
 Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(initMyCode);
</script>
于 2012-11-29T07:20:41.493 回答
-1

您是否已经尝试在jQuery的“准备就绪”中添加您的代码?

于 2012-12-01T00:07:01.067 回答