我正在尝试解决在更新面板中使用内联脚本的问题。这个问题通常可以通过使用 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()。
有人对此问题有可行的解决方案吗?