如何防止整个页面张贴回来,而更新更新面板
本文关键字:更新 何防止 回来 张贴 | 更新日期: 2023-09-27 18:18:15
我想做一个asp 4.0网站,在一个页面中显示视频。我编写了代码来显示视频,并使用更新面板每10秒刷新一次内容。但是整个页面都在回复。这是我的代码。
<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>
c#代码如下
dbOperation db = new dbOperation();
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
SqlDataReader dr = db.ExRdr("Select * from video");
if (dr.HasRows)
{
Repeater1.DataSource = dr;
Repeater1.DataBind();
}
else
{
Lbl_error.Text = "No data found.";
}
db.ConClose();
}
}
定时器代码
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
中有一个结束标记,但它的开始标记缺失。