Ajax ASP.NET: Увольнение UpdatePanel после загрузки страницы завершено

Из n4296 [dcl.init]:

[Примечание: поскольку () не разрешено синтаксисом для инициализатора , X a(); не является объявление объекта класса X, но объявление функции не принимает аргумента и возвращает X. Форма () разрешена в некоторых других контекстах инициализации (5.3. 4, 5.2.3, 12.6.2). -End note]

7
задан Shog9 19 September 2008 в 22:30
поделиться

8 ответов

Используйте управление таймером, которое будет запущено после определенного числа миллисекунд (чтобы страница загрузилась). В таймере отмечают обновление события панель обновления.

1
ответ дан 6 December 2019 в 19:45
поделиться

Взгляните на ScriptManager. RegisterStartupScript

Идея состоит в том, что Вы регистрируете сценарий для работы запуска (я верю, после того как страница загрузилась). Ваш сценарий должен вызвать функцию, которая вызывает сообщение назад через Ваш UpdatePanel

2
ответ дан 6 December 2019 в 19:45
поделиться

Я возился с предложениями ScriptManager - который я считаю, что в конечном счете получил бы работу, но мне кажется, что идею Таймера легче реализовать и не действительно(!) так большая часть взлома?!

Вот то, как я обновил свою панель после того, как начальный рендеринг страницы был завершен...

default.aspx

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="AJAXPostLoadCall._Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <h2>And now for a magic trick...</h2>
    <asp:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="True">
        </asp:ScriptManager>
        <div>
            <asp:UpdatePanel ID="UpdatePanel1" runat="server">
                <ContentTemplate>
                    <asp:Timer ID="Timer1" runat="server" Interval="2000" ontick="Timer1_Tick" />
                    <asp:Label ID="Label1" runat="server">Something magic is about to happen...</asp:Label>
                </ContentTemplate>
            </asp:UpdatePanel>

        </div>
    </form>
</body>
</html>

и код позади чтений default.aspx.cs

using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;

namespace AJAXPostLoadCall
{
    public partial class _Default : System.Web.UI.Page
    {

        protected void Page_Load(object sender, EventArgs e)
        {
        }

        public void DoMagic()
        {
            Label1.Text = "Abracadabra";
        }

        protected void Timer1_Tick(object sender, EventArgs e)
        {
            // Do the magic, then disable the timer
            DoMagic();
            Timer1.Enabled = false;
        }

    }
}

Так, загрузки страницы и Таймер (содержавший в UpdatePanel) запускают 2 secs после того, как страница загрузилась (я думаю - я не уверен, когда Таймер на самом деле запускается?). Текст метки переписывается, и затем Таймер отключен для остановки больше обновлений.

Достаточно простой - но может Вы, пуристы там говорят мне, если это - Ужасный Взлом?

8
ответ дан 6 December 2019 в 19:45
поделиться

Используя подход Tom со сценарием запуска, можно затем звонить:

__ doPostBack ('UpdatePanelName', '');

0
ответ дан 6 December 2019 в 19:45
поделиться

ScriptManager. RegisterStartupScript позволяет сценарию работать на запуске в панели обновления. если Вы используете старый ClientScript. RegisterStartupScript затем сценарий, который Вы представляете, будет вне границ udpate панели и таким образом не будет выполняться во время асинхронных загрузок страницы.

0
ответ дан 6 December 2019 в 19:45
поделиться

Большой палец вверх и спасибо SAL и всем остальным, ребята. Это решило мою большую проблему: моя процедура занимала около минуты, пока страница наконец отрендерилась и отобразилась.

Спасибо!

0
ответ дан 6 December 2019 в 19:45
поделиться

Выполнение подобных действий с помощью UpdatePanels, а не что-то понятное, БУДЕТ укусить вас, это просто вопрос времени.

1
ответ дан 6 December 2019 в 19:45
поделиться

С самого первого вопроса в этом посте я думаю, что пользователь ищет это сообщение, которое будет отображаться пользователю при загрузке панели обновлений. Просто поместите элемент управления UpdateProgress, подобный приведенному ниже, на вашу страницу чуть выше элемента управления UpdatePanel, и не стесняйтесь запускать событие в своем UpdatePanel, поместите свой внутренний код как обычно,

1
ответ дан 6 December 2019 в 19:45
поделиться
Другие вопросы по тегам:

Похожие вопросы: