全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

ASP.NET实现进度条效果

我们先看下进度条效果

我点击了按钮后他会显示进度页面,进度完成后,进度条消失,其实也是比较简单的了。

我们需要一个进度条代码文件ProgressBar.htm(注意:是没有head这些标签的)

<script language="javascript">
  function SetPorgressBar(pos) {
    //设置进度条居中

    var screenWidth = document.body.offsetWidth;
    ProgressBarSide.style.width = Math.round(screenWidth / 2) + "px";
    ProgressBarSide.style.left = Math.round(screenWidth / 4) + "px";
    ProgressBarSide.style.top = "50px";
    ProgressBarSide.style.height = "21px";
    ProgressBarSide.style.display = "block";

    //设置进度条百分比 
    ProgressBar.style.width = pos + "%";
    ProgressText.innerHTML = pos + "%";
  }

  function SetMaxValue(maxValue) {
    ProgressBarSide.style.width = maxValue + "px";
  }

  //完成后隐藏进度条
  function SetCompleted() {
    ProgressBarSide.style.display = "none";
  }

  function SetTitle(title) {
    ProgressTitle.innerHTML = title;
  }
</script>
<div id="ProgressBarSide" style="position: absolute; height: 21px; width: 100px;
  color: Silver; border-width: 1px; border-style: Solid; display: block">
  <div id="ProgressBar" style="position: absolute; height: 21px; width: 0%; background-color: #1475BB">
  </div>
  <div id="ProgressText" style="position: absolute; height: 21px; width: 100%; text-align: center">
  </div>
  <div id="ProgressTitle" style="position: absolute; height: 21px; top: 21px; width: 100%;
    text-align: center">
  </div>
</div>

然后需要一个进度条类ProgressBar.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.IO;

namespace ZhuoYueE.Dop.Web.UI
{
  /// <summary>
  ///显示进度条
  /// </summary>
  public class ProgressBar : System.Web.UI.Page
  {
    /// <summary>
    /// 最大值
    /// </summary>
    private int MaxValue
    {
      get
      {
        if (ViewState["MaxValue"] == null)
        {
          return 0;
        }
        else
        {
          return Convert.ToInt32(ViewState["MaxValue"]);
        }
      }
      set
      {
        ViewState["MaxValue"] = value;
      }
    }
    /// <summary>
    /// 当前值
    /// </summary>
    private int ThisValue
    {
      get
      {
        if (ViewState["ThisValue"] == null)
        {
          return 0;
        }
        else
        {
          return Convert.ToInt32(ViewState["ThisValue"]);
        }
      }
      set
      {
        ViewState["ThisValue"] = value;
      }
    }
    /// <summary>
    /// 当前页面
    /// </summary>
    System.Web.UI.Page m_page;
    /// <summary>
    /// 功能描述:构造函数
    /// 作  者:huangzh
    /// 创建日期:2016-05-06 11:54:34
    /// 任务编号:
    /// </summary>
    /// <param name="page">当前页面</param>
    public ProgressBar(System.Web.UI.Page page)
    {
      m_page = page;
    }

    public void SetMaxValue(int intMaxValue)
    {
      MaxValue = intMaxValue;
    }

    /// <summary>
    /// 功能描述:初始化进度条
    /// 作  者:huangzh
    /// 创建日期:2016-05-06 11:55:26
    /// 任务编号:
    /// </summary>
    public void InitProgress()
    {
      //根据ProgressBar.htm显示进度条界面
      string templateFileName = AppDomain.CurrentDomain.BaseDirectory + "ProgressBar.htm";
      StreamReader reader = new StreamReader(@templateFileName, System.Text.Encoding.GetEncoding("GB2312"));
      string strhtml = reader.ReadToEnd();
      reader.Close();
      m_page.Response.Write(strhtml);
      m_page.Response.Flush();
    }

    /// <summary>
    /// 功能描述:设置标题
    /// 作  者:huangzh
    /// 创建日期:2016-05-06 11:55:36
    /// 任务编号:
    /// </summary>
    /// <param name="strTitle">strTitle</param>
    public void SetTitle(string strTitle)
    {
      string strjsBlock = "<script>SetTitle('" + strTitle + "'); </script>";

      m_page.Response.Write(strjsBlock);
      m_page.Response.Flush();
    }

    /// <summary>
    /// 功能描述:设置进度
    /// 作  者:huangzh
    /// 创建日期:2016-05-06 11:55:45
    /// 任务编号:
    /// </summary>
    /// <param name="percent">percent</param>
    public void AddProgress(int intpercent)
    {
      ThisValue = ThisValue + intpercent;
      double dblstep = ((double)ThisValue / (double)MaxValue) * 100;

      string strjsBlock = "<script>SetPorgressBar('" + dblstep.ToString("0.00") + "'); </script>";

      m_page.Response.Write(strjsBlock);
      m_page.Response.Flush();
    }


    public void DisponseProgress()
    {
      string strjsBlock = "<script>SetCompleted();</script>";
      m_page.Response.Write(strjsBlock);
      m_page.Response.Flush();
    }
  }
}

然后就是调用方法了,调用很简单,在页面的按钮事件或者其他什么地方加入代码,如在按钮事件里这么用

protected void btnImport_Click(object sender, EventArgs e)
    {
      ProgressBar pb = new ProgressBar(this);
      pb.SetMaxValue(110);
      pb.InitProgress();
      pb.SetTitle("这是一个测试数据");
      for (int i = 1; i <= 110; i++)
      {
        pb.AddProgress(1);
        //此处用线程休眠代替实际的操作,如加载数据等
        System.Threading.Thread.Sleep(50);
      }
      pb.DisponseProgress();
    }

怎么样,是不是很简单呢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# asp.net  # 进度条  # Asp.net基于ajax和jquery-ui实现进度条  # asp.net mvc 实现文件上传带进度条的思路与方法  # asp.net文件上传带进度条实现案例(多种风格)  # asp.net单文件带进度条上传的解决方案  # Asp.Net 无刷新文件上传并显示进度条的实现方法及思路  # asp.net 生成静态页时的进度条显示  # 利用Asp.Net回调机制实现进度条  # ASP.NET技巧:教你制做Web实时进度条  # ASP.NET MVC使用jQuery ui的progressbar实现进度条  # 创建日期  # 很简单  # 完成后  # 这是一个  # 他会  # 什么地方  # 或者其他  # 如在  # 先看  # 大家多多  # 测试数据  # 加载  # 用线  # title  # SetTitle  # ProgressTitle  # position  # maxValue  # div 


相关文章: 建站之星安装需要哪些步骤及注意事项?  css网站制作参考文献有哪些,易聊怎么注册?  建站之星伪静态规则如何设置?  建站与域名管理如何高效结合?  公司门户网站制作流程,华为官网怎么做?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  韩国服务器如何优化跨境访问实现高效连接?  C#如何在一个XML文件中查找并替换文本内容  深圳网站制作平台,深圳市做网站好的公司有哪些?  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  一键网站制作软件,义乌购一件代发流程?  C#如何序列化对象为XML XmlSerializer用法  网站专业制作公司有哪些,做一个公司网站要多少钱?  建站之星代理如何获取技术支持?  如何基于云服务器快速搭建个人网站?  如何配置FTP站点权限与安全设置?  建站之星与建站宝盒如何选择最佳方案?  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  如何零基础在云服务器搭建WordPress站点?  建站之星导航如何优化提升用户体验?  ,购物网站怎么盈利呢?  建站主机类型有哪些?如何正确选型  MySQL查询结果复制到新表的方法(更新、插入)  建站之星如何通过成品分离优化网站效率?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何通过FTP服务器快速搭建网站?  建站主机选购指南:核心配置与性价比推荐解析  临沂网站制作公司有哪些,临沂第四中学官网?  专业公司网站制作公司,用什么语言做企业网站比较好?  建站主机与虚拟主机有何区别?如何选择最优方案?  如何实现建站之星域名转发设置?  建站之星后台密码如何安全设置与找回?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  黑客入侵网站服务器的常见手法有哪些?  高性价比服务器租赁——企业级配置与24小时运维服务  定制建站流程步骤详解:一站式方案设计与开发指南  北京网站制作的公司有哪些,北京白云观官方网站?  如何快速搭建支持数据库操作的智能建站平台?  网站图片在线制作软件,怎么在图片上做链接?  大连网站制作公司哪家好一点,大连买房网站哪个好?  定制建站如何定义?其核心优势是什么?  h5网站制作工具有哪些,h5页面制作工具有哪些?  动图在线制作网站有哪些,滑动动图图集怎么做?  如何在局域网内绑定自建网站域名?  如何快速搭建安全的FTP站点? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。