Как получить событие ASP.NET page_load для запуска обновления AJAX UpdatePanel
У меня есть страница в ASP.NET, на которой есть несколько панелей обновления. После загрузки страницы я хочу, чтобы панели обновления запускали обновление.
Я работаю, используя этот ответ, который говорит, чтобы разместить этот Javascript на странице.
$(document).ready(function () {
window.__doPostBack('<%= hiddenAsyncTrigger.ClientID %>', 'OnClick');
});
Тем не менее, это вызывает спам событие click, потому что событие load вызывает другую загрузку...??
Все панели обновлений работают нормально, проблема в том, чтобы запуск обновления происходил один раз после загрузки страницы.
2 ответа
Решение
Закончилось решение этой проблемы с Javascript, вызывающим скрытую кнопку в панели обновления
JS
var timer;
var polling_interval = 30000;
$(document).ready(function () {
TriggerUpdatePanelUpdate();// update as soon as DOM is ready
StartPolling();
});
function StartPolling() {
PollLoop();
}
function StopPolling() {
clearTimeout(timer);
}
function PollLoop() {
timer = setTimeout(
function() {
TriggerUpdatePanelUpdate();
PollLoop();
},
polling_interval
);
}
function TriggerUpdatePanelUpdate() {
document.getElementById('hiddenAsyncTrigger').click();
}
HTML
<asp:Button ID="hiddenAsyncTrigger" runat="server" OnClick="DoWork" Text="AsyncUpdate" style="display: none;"/>
Используйте клиентский элемент управления вместо серверного:
<%@ Page Language="C#" %>
<script runat="server">
protected string CurrentTime()
{
return DateTime.Now.ToString();
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Untitled Page</title>
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script language="JavaScript">
$(document).ready(function () {
$("#Updater").click()
});
</script>
</head>
<body>
<form id="MyForm" runat="server">
<div>
Outside the panel: <%=CurrentTime() %>
</div>
<br />
<br />
<asp:ScriptManager ID="ScriptManager1" EnablePartialRendering="true" runat="server" />
<asp:UpdatePanel ID="panel" runat="server" UpdateMode="conditional">
<ContentTemplate>
<div>
Inside the panel: <%=CurrentTime() %>
</div>
<input type="submit" id="Updater" style="display: none" />
</ContentTemplate>
</asp:UpdatePanel>
</form>
</body>
</html>
Другое решение - без скрытого триггера, используя __doPostBack
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApplicationTest.WebForm1" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<title>Untitled Page</title>
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script language="JavaScript">
$(document).ready(function () {
__doPostBack('panel', '');
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
Outside the panel: <%=CurrentTime() %>
</div>
<br />
<br />
<asp:ScriptManager ID="ScriptManager1" EnablePartialRendering="true" runat="server" />
<asp:UpdatePanel ID="panel" runat="server" UpdateMode="conditional">
<ContentTemplate>
<div>
Inside the panel: <%=CurrentTime() %>
</div>
<input type="submit" id="Updater" style="display: none" />
</ContentTemplate>
</asp:UpdatePanel>
</form>
</body>
</html>
using System.Web.UI;
using System.Web.UI.WebControls;
namespace WebApplicationTest
{
public partial class WebForm1 : System.Web.UI.Page
{
protected string CurrentTime()
{
System.Diagnostics.Debug.WriteLine("CurrentTime was called");
return DateTime.Now.ToString();
}
protected void Page_Load(object sender, EventArgs e)
{
System.Diagnostics.Debug.WriteLine("PageLoad was called");
}
}
}