C# 更新面板时如何防止整页回发
我正在尝试制作一个asp 4.0网站,该网站在页面中显示视频。我编写代码显示视频,并使用“更新面板”每10秒刷新一次内容。但整个页面正在发回。 这是我的密码C# 更新面板时如何防止整页回发,c#,asp.net,C#,Asp.net,我正在尝试制作一个asp 4.0网站,该网站在页面中显示视频。我编写代码显示视频,并使用“更新面板”每10秒刷新一次内容。但整个页面正在发回。 这是我的密码 <asp:UpdatePanel ID="UpdatePanel1" runat="server" ChildrenAsTriggers="true" UpdateMode="Conditional"> <ContentTemplate>
<asp:UpdatePanel ID="UpdatePanel1" runat="server" ChildrenAsTriggers="true" UpdateMode="Conditional">
<ContentTemplate>
<asp:Repeater ID="Repeater1" runat="server">
<HeaderTemplate></HeaderTemplate>
<ItemTemplate>
<table border="1" align="left">
<tr><td>
<div style="float:left;">
<asp:Label ID="Label1" runat="server"
Text='<%# DataBinder.Eval(Container.DataItem, "id") %>' Visible="false"></asp:Label>
<div style="background:
url(http://www.dollarshaveclub.com/skin/frontend/dsc-test/dsc-
theme/images/video_placeholder.png) no-repeat; padding: 0px; width: 100px;
height: 70px;"></div>
<br /><asp:LinkButton Text="View" ID="remove" runat="server"
ImageUrl="images/remove.png" CommandName="remove" UseSubmitBehavior="False"
/><br />
<span class="projectboldtxt"><%# DataBinder.Eval(Container.DataItem,
"video_caption") %></span>
<span class="projectboldtxt"><%#
DataBinder.Eval(Container.DataItem, "video_date") %></span>
</div>
</td></tr>
</table>
</ItemTemplate>
<FooterTemplate><br /></FooterTemplate>
</asp:Repeater>
</ContentTemplate>
<Triggers>
<asp:AsyncPostBackTrigger ControlID="Timer1" EventName="Tick" />
</Triggers>
</asp:UpdatePanel>
定时器代码
protected void Timer1_Tick(object sender, EventArgs e)
{
SqlDataReader dr = db.ExRdr("Select * from video");
if (dr.HasRows)
{
Repeater1.DataSource = dr;
Repeater1.DataBind();
}
else
{
Lbl_error.Text = "No data found.";
}
db.ConClose();
UpdatePanel1.Update();
}
我的问题是:如何在更新更新面板时防止整个页面回发???您的
UpdatePanel
在ItemTemplate
中有一个结束标记,但它的开始标记丢失。发展到MVC/Web API,并为JS消费提供适当的API,或者保持整个页面的刷新。这是经典ASP.Net AFAIK固有的设计限制。您能说明UpdatePanel从哪里开始吗?计时器是否在UpdatePanel内?我已将计时器和工具脚本管理器放置在更新面板外。完整的显示为您的请求@DanielSanchez@Machinarius不,Web表单能够在不回发的情况下向服务器发送数据或从服务器发送数据。直接使用AJAX或通过UpdatePanel可以做到这一点。@mason,正如您所看到的,我也尝试过
protected void Timer1_Tick(object sender, EventArgs e)
{
SqlDataReader dr = db.ExRdr("Select * from video");
if (dr.HasRows)
{
Repeater1.DataSource = dr;
Repeater1.DataBind();
}
else
{
Lbl_error.Text = "No data found.";
}
db.ConClose();
UpdatePanel1.Update();
}