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

来源:互联网 发布:不吾知其亦已兮句式 编辑:程序博客网 时间:2024/06/11 19:32

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

1

 

设计这样的一个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>
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 广州居住证回执单丢了怎么办 惠阳居住证回执单丢了怎么办 南京居住证换地方了怎么办 买家退回的商品有问题怎么办 农转农户口手续怎么办 原房东不迁户口我怎么办 户主信息页掉了怎么办 户主变了户口本首页怎么办 大人户口迁走小孩户口怎么办 网银转账处理中怎么办 教育部学籍在线验证报告有错怎么办 验证码连续输入三次错误怎么办 交通运输监察大队截车了怎么办 平安安康续保没成功怎么办 危险品经营许可证到期了怎么办 郑万350渝万怎么办 厂里饭堂的饭好难吃怎么办 学校的食堂饭菜不好不卫生怎么办 亲戚借钱我真没有怎么办 榴莲肉酸了吃了怎么办 亲戚赖在家里住怎么办 食堂饭菜味道差该怎么办 被监视居住公安打电话睡着了怎么办 鱼缺氧浮上水面怎么办 车载低音炮有电流声怎么办 925纯银变黑了怎么办 银子放久了变黑怎么办 高铁票网上售空怎么办 高铁票出票失败怎么办 高铁票名字打错怎么办 高铁票姓名错了怎么办 高铁票弄丢了怎么办 用过的车票丢了怎么办 高铁票被水洗了怎么办 沈阳地铁卡丢了怎么办 火车票没写检票口怎么办 吃鸡听的脚步声距离太近怎么办 检票时车票丢了怎么办 高铁出站没检票怎么办 高铁来不及取票怎么办 被发现假的增值税发票怎么办