如果asp.net页面加载时间过长,怎样在加载时显示提示?

解决方案 »

  1.   

    如果说后台执行时间过程,请改用ajax实现,先输出很少的内容,然后采用ajax提取后面的内容。
      

  2.   

    孟子老大,用AJAX提取大量内容的话,效率如何啊?再问一句:百万级的数据,如何提高模糊查询的效率?如果是前台加载时间长的话,用个DIV的显示与隐藏就可以显示提示了.
      

  3.   

    孟子老大的意思是选输出一个比较小的提示(比方提取信息中之类的),然后马上用AJAX从后台取数据,取完把把提示去掉,显示数据.
      

  4.   

    显示"正在加载中...."
    建一个html页面.代码如下:
    <!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" id="mainWindow">
    <head>
        <title>无标题页</title>
        <script language="javascript" type="text/javascript">
            function SetPorgressBar(pos)
            {
                //设置进度条居中
                var screenHeight = window["mainWindow"].offsetHeight;
                var screenWidth = window["mainWindow"].offsetWidth;
                ProgressBarSide.style.width = Math.round(screenWidth / 4);
                ProgressBarSide.style.left = Math.round(screenWidth / 3);
                ProgressBarSide.style.top = Math.round(screenHeight / 2);
                ProgressBarSide.style.height = "21px";
                ProgressBarSide.style.display = "";            //设置进度条百分比                       
                ProgressBar.style.width = pos + "%";
                ProgressText.innerHTML = "正在加载,请稍后....." + pos + "%";
            }        //完成后隐藏进度条
            function SetCompleted()
            {       
                ProgressBarSide.style.display = "none";
                MyTable.style.display="none";
            }
         </script>  
    </head>
    <body>
        <!--<div id="mydiv" style="width: 224px">数据处理中....</div>-->
            <div id="ProgressBarSide" style="position:absolute;height:21px;width:100px;color:Silver;border-width:1px;border-style:Solid;display:none">
            <div id="ProgressBar" style="position:absolute;height:21px;width:0%;background-color:PaleTurquoise"></div>
            <div id="ProgressText" style="position:absolute;height:21px;width:100%;text-align:center"></div>
            
        </div>
        </body>
    </html>
    在你需要显示的页面Page_load:
    if (!Page.IsPostBack)
            { 
                beginProgress();            for (int i = 1; i <= 100; i++)
                {
                    setProgress(i);                //此处用线程休眠代替实际的操作,如加载数据等
                    System.Threading.Thread.Sleep(20);
                }            finishProgress(); 
            }
    函数:
    /// <summary>
        ///显示进度条
        /// </summary>    private void beginProgress()
        {
            //根据ProgressBar.htm显示进度条界面
            string templateFileName = Path.Combine(Server.MapPath("."), "ProgressBar.htm");
            StreamReader reader = new StreamReader(@templateFileName,System.Text.Encoding.GetEncoding("GB2312"));
            string html = reader.ReadToEnd();
            reader.Close();
            Response.Write(html);
            Response.Flush();
        }    private void setProgress(int percent)
        {
            string jsBlock = "<script>SetPorgressBar('" + percent.ToString() + "'); </script>";
            Response.Write(jsBlock);
            Response.Flush();
        }    private void finishProgress()
        {
            string jsBlock = "<script>SetCompleted();</script>";
            Response.Write(jsBlock);
            Response.Flush();
        }
      

  5.   

    楼上的我试了  没问题
    但是怎么感觉用这个和不提示直接显示速度差很多?还有MyTable是什么东西?
      

  6.   

    谢谢各位回复。还不打算结贴。请各位多发表自己的想法,thank you.
      

  7.   

    yangpeiyu(︷1.Er℡﹎) 
    讲的已经是非常的清楚的,这个效果是可以的
      

  8.   

    page_load代码给如何添加啊?前后的标签是什么?请高手指点。
      

  9.   

    page_load那段代码该如何添加啊?前后的标签是什么啊?请高手指点。
      

  10.   

    我在用yangpeiyu提供的代码的时候有个问题,比如我原先的Page_Load方式如下
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                if (!string.IsNullOrEmpty(Request.QueryString["bk_Id"]))
                {
                    getPageData(Bbk_Id);//加载页面时根据ID号获取相应的数据
                }
             }
        }
    如用用了这个加载效果,那Page_Load方法应该怎么改?