我在ASP.NET(.ascx文件)中的用户控件中使用更新面板。下面是我的HTML标记
<asp:ScriptManager EnablePartialRendering="true"
ID="ScriptManager1" runat="server"></asp:ScriptManager>
<div>
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional" ChildrenAsTriggers="true" >
<ContentTemplate>
<asp:Label ID="Label1" runat="server" /><br />
<asp:Button ID="Button1" runat="server" Text="Update Panel" OnClick="Button1_Click" />
</ContentTemplate>
<Triggers>
<asp:AsyncPostBackTrigger ControlID="Button1" EventName="Click">
</asp:AsyncPostBackTrigger>
</Triggers>
</asp:UpdatePanel>
</div>
这是我的代码隐藏
public partial class sample: System.Web.UI.Control
{
protected void Button1_Click(object sender, EventArgs e)
{
Label1.Text = DateTime.Now.ToLongTimeString();
UpdatePanel1.Update();
}
}
如果我使用PostBackTrigger,那么它工作正常但是回发整个页面(这是我不想要的)我只需要刷新更新面板。
这是我的aspx页面标记(它是Sitecore驱动的网站,因此所有子布局都加载到Sitecore占位符中)
<form id="form2" runat="server">
<section class="page">
<sc:Placeholder runat="server" ID="mainPlaceholder" Key="content" />
</section>
</form>
对不起,由于某些安全原因,无法发布整个页面
谢谢
答案 0 :(得分:0)
要尝试的一些事情。 (它对我来说很好。)
您还设置了一些等于默认值的属性,因此您可以删除它们:
<asp:ScriptManager ID="ScriptManager1" runat="server"></asp:ScriptManager>
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
<asp:Label ID="Label1" runat="server" /><br />
<asp:Button ID="Button1" runat="server" Text="Update Panel"
OnClick="Button1_Click" />
</ContentTemplate>
</asp:UpdatePanel>
protected void Button1_Click(object sender, EventArgs e)
{
Label1.Text = DateTime.Now.ToLongTimeString();
//UpdatePanel1.Update();
}
答案 1 :(得分:0)
最后,我找到了解决此问题的解决方案。我的整个HTML标记仍然相同,只需要评论或取消触发器。我刚刚评论了标签的内部HTML,它一切都按预期工作。
答案 2 :(得分:-1)