MVC实现有关时间的进度条,使用jQuery ui的progressbar

在电商网站中,有时候通过进度条来直观地显示用户是否到期以及用户当前的状态。

设计这样的一个Model。

    public class User
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public int CoopTime { get; set; }
        public DateTime JoinTime { get; set; }
    }

以上,合作时长属性CoopTime,和加入时间属性JoinTime是和进度密切相关的2个属性。

在HomeController中,一个action方法用来显示界面,一个用来接收来自视图的GET请求,返回json数据。

        public ActionResult Index()
        {
            return View();
        }

        public ActionResult GetStatus()
        {
            User user = new User()
            {
                Id = 1,
                Name = "某某用户",
                CoopTime = 1,
                JoinTime = new DateTime(2014, 3, 20)
            };

            //判断合作是否已经到期
            int result = DateTime.Compare(DateTime.Now, user.JoinTime.AddYears(user.CoopTime));

            if (result <= 0) //当前时间比合作到期时间早,合作未到期
            {
                //计算时间
                var pastDays = (DateTime.Now.Subtract(user.JoinTime)).TotalDays;
                var oneYearDays = (user.JoinTime.AddYears(user.CoopTime).Subtract(user.JoinTime)).TotalDays;
                var pastPercentage = (pastDays / oneYearDays) * 100;

                var dataSuccess = new { msg = true, p = pastPercentage };
                return Json(dataSuccess, JsonRequestBehavior.AllowGet);

            }
            else //当前时间比合作到期时间晚,合作已到期
            {
                var dataFail = new { msg = false, p = 100 };
                return Json(dataFail, JsonRequestBehavior.AllowGet);
            }
        }

    }


以上,

● 使用DateTime的静态方法Compare来比较2个时间,一个是当前时间,另一个是加入时间 + 合作时长,如果结果小于或等于0,就表示没有过期。
● 使用DateTime的静态方法Subtract来给2个时间做减法。

Home/Index.cshtml中,当页面加载完毕后,向服务端发出一个异步GET请求,把返回的数据显示到progressbar中。

<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index</title>
    <link href="~/Content/themes/base/jquery-ui.css" rel="stylesheet" />
    <script src="~/Scripts/jquery-1.8.2.min.js"></script>
    <script src="~/Scripts/jquery-ui-1.8.24.min.js"></script>
    <script type="text/javascript">
        $(function () {

            $.getJSON(‘@Url.Action("GetStatus","Home")‘, function(data) {
                if (data.msg == true) {
                    var temp = parseInt(data.p);
                    $(‘#p‘).progressbar({
                        value: temp
                    });
                } else {
                    $(‘#message‘).text(‘已到期‘);
                    $(‘#p‘).progressbar({
                        value: parseInt(data.p)
                    });
                }
            });
        });
    </script>
</head>
<body>
    <div id="p">
    </div>
    <div>
        <span id="message"></span>
    </div>
</body>

MVC实现有关时间的进度条,使用jQuery ui的progressbar,布布扣,bubuko.com

时间: 2024-10-01 02:36:10

MVC实现有关时间的进度条,使用jQuery ui的progressbar的相关文章

MVC自定义编辑视图,DateTime类型属性显示jQuery ui的datapicker

实现的效果为:在编辑视图中,对DateTime类型的属性,显示jQuery UI的datepicker.效果如下: Student.cs public class Student    {        public int Id { get; set; }        public string Name { get; set; }        public DateTime? JoinTime { get; set; }    } HomeController: public class

赞!带进度条的 jQuery 文件拖放上传插件

jQuery File Uploader 是一个 jQuery 文件拖放上传插件,包括 Ajax 上传和进度条效果.作者编写这个插件的想法是要保持它非常简单,不像其他的插件,很多的标记,并提供一些 Hack 的方式使之兼容那些古老的浏览器.jQuery File Uploader 重点是现代浏览器,而且还提供了一个方法让你知道什时候插件不支持使用. 立即下载      在线演示 jQuery File Uploader 是一个 jQuery 文件拖放上传插件,包括 Ajax 上传和进度条效果.作

网页加载进度条的实现

本次主要介绍一下网页加载进度的实现.如下图,在页面加载的时候,上方红色的进度条 网页加载进度的好处是能够更好的反应当前网页的加载进度情况,loading进度条可用动画的形式从开始0%到100%完成网页加载这一过程.但是目前的浏览器并没有提供页面加载进度方面的接口,也就是说页面还无法准确返回页面实际加载的进度,本文中我们使用jQuery来实现页面加载进度条效果. 首先我们要知道的是,目前没有任何浏览器可以直接获取正在加载对象的大小.所以我们无法通过数据大小来实现0-100%的加载显示过程. 因此我

第二周:PSP&amp;进度条

PSP: 一.词频统计改进 1.表格:     C类型 C内容 S开始时间 E结束时间 I时间间隔 T净时间(mins) 预计花费时间(hrs) 学习 <构建之法>.Java 8:46 12:18 28 152 3  分析 读需求.分析需求 13:12 14:52 30 130 1.5  编码 具体编码 14:54 20:17 82 241 4  调试 修改代码.代码复审 20:32 21:54 18 64 1 总结 总结结果 23:06 23:39 0 33 0.5 2.饼图: 3.总结分析

JQuery入门——进度条

越来越觉得常规javascript已经跟不上节奏了,打算学点进阶的,从JQuery学起. JQuery是一个Javascript库,可以从JQuery.com下载,放到本地,用 <script src="jquery.js"></script> 语句来引用.如果不想下载jquery,可以引用web上的jquery库,从google或微软的服务器上引用他们的jquery库. 引用google的jquery库: <script src="http:/

ajax文件上传进度条

写在前面: 思路:首先将表单提交servlet,servlet中做文件上传处理,上传的参数封装成对象存入session中,提交到的页面为隐藏的iframe窗口.然后使用ajax异步请求获取session中的对象,并将对象转换成json对象输出出来.当对象状态为上传完成或操作异常时将session中对应的属性清除掉.异步操作的回调函数可以使用var jinduStatus = eval("("+xmlHttp.responseText+")") 的方法将json转换为

timeline时间轴进度“群英荟萃”

timeline时间轴进度“群英荟萃” 是日,无论PC项目还是APP,都涉及到了通常称谓的“时间轴”UI展现布局.产品和设计师都喜欢横向.纵向的时间轴来传达产品的寓意.如此,如斯!总结一套 timeline时间轴 大家族的“群英荟萃”. 1.时间轴进度条-PC版 结构简单的如下: <div class="pub-wrap"> <ul class="pub-process"> <li class="active">

Android ProgressBar 进度条荧光效果

http://blog.csdn.net/ywtcy/article/details/7878289 这段时间做项目,产品需求,进度条要做一个荧光效果,类似于Android4.0 浏览器中进度条那种样子.刚开始,百思不得其姐啊,还以为是用sharp文件或者canvas直接画出来的.后来一怒之下,把系统浏览器的apk包给解开了,坑爹的是,那个荧光效果的进度条居然是用的一张.9的图片,恍然大悟啊,不过,谷哥还是强大了一下,他的进度条用的并不是ProgressBar,而是重写的ImageView,当然

Centos 6下的wget进度条多行显示bug

最近一段时间因为需求新部署了一台Centos 6,在使用wget下载源码编译包的时候出现了一个非常让人头疼的问题就是进度条会不断的显示"eta(英国中部时间)"然后进度条就不断的替换,这样根本无法正常使用,于是就上google上找了下,原来是Centos 6的wget中文字体翻译出错 #错误的信息提示 msgstr " eta(英国中部时间) %s" #正确的信息提示 msgstr " eta %s" 这个不知道是哪个程序员在写中文的wget.m