华域联盟 .Net Asp.net基于ajax和jquery-ui实现进度条

Asp.net基于ajax和jquery-ui实现进度条

Asp.net基于ajax和jquery-ui实现进度条
 更新时间:2020年12月03日 11:11:15   作者:David Huang  

这篇文章主要介绍了Asp.net基于ajax和jquery-ui实现进度条,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

  前台用ajax不停进行查询,直到任务完成。进度条用的是jquery-ui。后台用一般处理程序处理相应,进度信息保存在HttpContext.Application中。
  代码作为简单示例,实际应用时应对资源释放、防止多线程混乱等做进一步控制。
效果图:
  
代码:
前台:

<!DOCTYPE html>
<html xmlns="www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<script src="Scripts/jquery-2.1.4.min.js"></script>
<script src="Scripts/jquery-ui-1.11.4.min.js"></script>
<link href="Content/themes/base/all.css" rel="external nofollow" rel="stylesheet" />
<script type="text/javascript">
function GetProgress() {
$.ajax({
url: "/Handler1.ashx",
type: "POST",
data: { "RequestType": "AjaxRequest", "Method": "GetProgress" },
success: function (data) {
if (data != -1) {
//工作没有结束,继续查询进度
setTimeout(GetProgress, 100);
$("#progress").html(data);
$("#progressbar").progressbar({ value: parseInt(data) });
} else {
//工作完成
$("#progress").html("done");
$("#progressbar").progressbar({ value: 100 });
$("#btn1").attr("disabled", false);
}
}
});
}

function DoWork() {
//禁用按钮
$("#btn1").attr("disabled", true);
$.ajax({
url: "/Handler1.ashx",
type: "POST",
data: { "RequestType": "AjaxRequest", "Method": "DoWork" }
});
//开始查询进度
setTimeout(GetProgress, 500);
}
</script>

</head>
<body>
<div>
<input type="button" id="btn1" value="开始" onclick="DoWork();" />
<label id="progress"></label>
<div id="progressbar"></div>
</div>
</body>
</html>

后台:

// 2015年12月16日 09:53:11
// David Huang
// 进度条示例
namespace ProgressTest
{
using System;
using System.Threading;
using System.Web;

/// <summary>
/// Handler1 的摘要说明
/// </summary>
public class Handler1 : IHttpHandler
{
// context
private HttpContext context;

public bool IsReusable
{
get
{
return false;
}
}

public void ProcessRequest(HttpContext context)
{
this.context = context;
if (context.Request["RequestType"] == "AjaxRequest")
{
if (context.Request["Method"] == "GetProgress")
{
context.Response.Clear();
context.Response.Write(this.GetProgress());
context.Response.End();
}
else
{
this.DoWork();
}
}
}

/// <summary>
/// 开始工作
/// </summary>
private void DoWork()
{
for (int i = 0; i < 100; i++)
{
// 记录进度
// 实际应用中需要进一步控制(利用用户信息、cookies等),防止并发造成混乱
this.context.Application["progress"] = i + 1;
Random r = new Random();
Thread.Sleep(r.Next(10, 100));
}
// 完成后释放资源
this.context.Application["progress"] = null;
}

/// <summary>
/// 查询进度
/// </summary>
/// <returns>进度</returns>
private int GetProgress()
{
if (this.context.Application["progress"] != null)
{
return (int)this.context.Application["progress"];
}
else
{
return -1;
}
}
}
}

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

您可能感兴趣的文章:ASP.NET实现进度条效果asp.net mvc 实现文件上传带进度条的思路与方法asp.net文件上传带进度条实现案例(多种风格)asp.net单文件带进度条上传的解决方案Asp.Net 无刷新文件上传并显示进度条的实现方法及思路asp.net(c#)开发中的文件上传组件uploadify的使用方法(带进度条)asp.net 在客户端显示服务器端任务处理进度条的探讨asp.net 生成静态页时的进度条显示

asp
net
ajax
jquery
ui
进度条

相关文章
asp.net中强制取消TFS2008中其它成员的签出文件的方法有个项目,以前的成员离职了,刚好又签出了一个文件在TFS中并且上了锁,导致后面的维护无法签入和生成。在网上查了一下,找到了如下解决办法

2012-08-08
asp.net Repeater中使用if的代码asp.net Repeater中使用if的和asp.net日期绑定的转换 2009-02-02
asp.net下获取远程网页的内容之二(downmoon原创)asp.net下获取远程网页的内容之二(downmoon原创)... 2007-04-04
获取App.config配置文件中的参数值这篇文章介绍了获取app.config配置文件中的参数值方法,首先是要添加System.Configuration引用,其次类文件中必须有 using System.Configuration;再次App.config添加,最后向App.config配置文件添加参数,下面通过列子给大家讲解下,需要的朋友可以参考下 2015-07-07
asp.net 无刷新翻页就是这么简单 前两天看了一个自定义分页控件,和AspNetPager一样是实现IPostBackEventHandler接口,不过简洁许多,就想能不能实现ICallbackEventHandler接口做到无刷新分页呢?想到了就马上去做,终于,设想变成了现实!! 2010-03-03
LiteralControl ASP.NET中的另类控件对于LiteralControl控件的应用比较少,今天突然看到了,就弄个明白为好,所以总结出来,供大家一起学习 2012-01-01
VS Code 1.26 发布 有你想要的新特性?VS Code 1.26 发布,有你想要的新特性吗?这篇文章主要为大家详细介绍了VS Code 1.26一些主要的更新亮点,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 2018-08-08
.NET下模拟数组越界的方法详解这篇文章主要给大家介绍了关于.NET下模拟数组越界的相关资料,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 2019-01-01
asp.net中通过ALinq让Mysql操作变得如此简单当大家已经习惯了使用.net 去操作SQL Server,有多少人曾经尝试过使用.net 去操作Mysql数据库!在.net 的光环下,Mysql是显得如此微不足道!但是Mysql的开源又是如此具有诱惑。 2011-07-07
ASP.NET笔记之 Httphandler的操作详解本篇文章小编为大家介绍,ASP.NET笔记之 Httphandler的操作详解。需要的朋友参考下 2013-04-04

最新评论

本文由 华域联盟 原创撰写:华域联盟 » Asp.net基于ajax和jquery-ui实现进度条

转载请保留出处和原文链接:https://www.cnhackhy.com/5015.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者:

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部