vue中多个倒计时实现代码实例


Posted in Javascript onMarch 27, 2019

下面给出一个效果图,我今天要说的就是实现下图这种多个倒计时

vue中多个倒计时实现代码实例

很多时候我们做只有一个倒计时的情况比较多,比较简单只需要一个定时器setInterval,算出来赋赋值就好,

但是需要多个倒计时的时候我们就要考虑把倒计时封装成通用的方法了

拿我自己的vue项目举个例

<!-- template -->
 <div v-for="(item,index) in list" :key="index" class="act_item">
 <h1>{{ item.title }}</h1>
 <img :src="item.pic" alt="">
 <div class="act_info">
  <h2><span>{{ item.count }}</span>个视频</h2>
  <div class="time">倒计时:{{ item.djs }}</div>
  <div class="clear"></div>
 </div>
 </div>
<script>
function InitTime(endtime){
 var dd,hh,mm,ss = null;
 var time = parseInt(endtime) - new Date().getTime();
 if(time<=0){
 return '结束'
 }else{
 dd = Math.floor(time / 60 / 60 / 24);
 hh = Math.floor((time / 60 / 60) % 24);
 mm = Math.floor((time / 60) % 60);
 ss = Math.floor(time % 60);
 var str = dd+"天"+hh+"小时"+mm+"分"+ss+"秒";
 return str;
 }
}
export default {
 data () {
	return {
  active: 'tab-container1',
  pinkFont:true,
  // 上拉刷新、下拉加载
  allLoaded: false, //如果为true,禁止上拉刷新
  autoFill: false, //取消自动填充,
  list: [],
 	}
 },
 created() {
 var ssss = [
  {"title": "小心愿,大梦想","pic":"../../assets/img/new/act1.jpg","count":"34","time":"1525293470350"},
  {"title": "杭州国际时装周童模招募","pic":"../../assets/img/new/act2.jpg","count":"36","time":"1525293470350"},
  {"title": "怪兽bobo全线代言火爆杭城的联名秀招募童模啦!","pic":"../../assets/img/new/act3.jpg","count":"74","time":"1529253270350"},
  {"title": "汉风唐韵 、别","pic":"../../assets/img/new/act2.jpg","count":"266","time":"1525753270350"},
  {"title": "听说你们想和明星超模同台“PK”?","pic":"../../assets/img/new/act1.jpg","count":"97","time":"1525253270450"},
 ];
 ssss.map( (obj,index)=>{
  this.$set(
  obj,"djs",InitTime(obj.time)
  );
 })
 this.list = ssss;
 },
 mounted() {
 setInterval( ()=> {
  for (var key in this.list) {
  var aaa = parseInt( this.list[key]["time"] );
  var bbb = new Date().getTime();
  var rightTime = aaa - bbb;
  if (rightTime > 0) {
   var dd = Math.floor(rightTime / 1000 / 60 / 60 / 24);
   var hh = Math.floor((rightTime / 1000 / 60 / 60) % 24);
   var mm = Math.floor((rightTime / 1000 / 60) % 60);
   var ss = Math.floor((rightTime / 1000) % 60);
  }
  this.list[key]["djs"] = dd + "天" + hh + "小时" + mm + "分" + ss + "秒";
  }
 }, 1000);
 
 },
 methods: {
 
 }
}
</script>

需要注意的是this.$set(obj,"djs",InitTime(obj.time)代码,在一个对象已经有了的情况下,假如此时object里没有djs这个元素,直接object.djs = "要赋的值"这样的做法是不正确的,可能会赋值成功,但是会出现很多奇怪的问题,推荐用

this.$set(object,'djs','要赋的值');

以上所述是小编给大家介绍的vue中多个倒计时实现详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript 放大镜 v1.0 基于Yui2 实现的放大镜效果
Mar 08 Javascript
jQuery 遍历-nextUntil()方法以及prevUntil()方法的使用介绍
Apr 26 Javascript
使用js实现关闭js弹出层的窗口
Feb 10 Javascript
js统计录入文本框中字符的个数并加以限制不超过多少
May 23 Javascript
javascript删除一个html元素节点的方法
Dec 20 Javascript
AngularJS使用ng-Cloak阻止初始化闪烁问题的方法
Nov 03 Javascript
Vue.js实现模拟微信朋友圈开发demo
Apr 20 Javascript
解决vue 项目引入字体图标报错、不显示等问题
Sep 01 Javascript
JS module的导出和导入的实现代码
Feb 25 Javascript
Vuex持久化插件(vuex-persistedstate)解决刷新数据消失的问题
Apr 16 Javascript
vue+springboot+element+vue-resource实现文件上传教程
Oct 21 Javascript
vue使用wavesurfer.js解决音频可视化播放问题
Apr 04 Vue.js
JavaScript偏函数与柯里化实例详解
Mar 27 #Javascript
vue实现鼠标移入移出事件代码实例
Mar 27 #Javascript
JavaScript惰性载入函数实例分析
Mar 27 #Javascript
微信小程序实现获取准确的腾讯定位地址功能示例
Mar 27 #Javascript
详解JS浏览器事件循环机制
Mar 27 #Javascript
详解如何更好的使用module vuex
Mar 27 #Javascript
原生js实现获取form表单数据代码实例
Mar 27 #Javascript
You might like
生成静态页面的php函数,php爱好者站推荐
2007/03/19 PHP
php 实现进制相互转换
2016/04/07 PHP
php实现遍历文件夹的方法汇总
2017/03/02 PHP
asp批量修改记录的代码
2008/06/25 Javascript
Extjs中的GridPanel隐藏列会显示在menuDisabled中解决方法
2013/01/27 Javascript
把input初始值不写value的具体实现方法
2013/07/04 Javascript
基于JQuery实现的图片自动进行缩放和裁剪处理
2014/01/31 Javascript
JavaScript中的Math 使用介绍
2014/04/21 Javascript
javascript实现一个简单的弹出窗
2016/02/22 Javascript
JS简单实现DIV相对于浏览器固定位置不变的方法
2016/06/17 Javascript
微信小程序购物商城系统开发系列-工具篇的介绍
2016/11/21 Javascript
vue.js选中动态绑定的radio的指定项
2017/06/02 Javascript
JavaScript实现无刷新上传预览图片功能
2017/08/02 Javascript
Node.Js生成比特币地址代码解析
2018/04/21 Javascript
vue.js使用3DES加密的方法示例
2018/05/18 Javascript
微信小程序设置滚动条过程详解
2019/07/25 Javascript
JavaScript如何获取一个元素的样式信息
2019/07/29 Javascript
微信小程序关键字变色实现代码实例
2019/12/13 Javascript
关于vue-cli3打包代码后白屏的解决方案
2020/09/02 Javascript
[05:46]DOTA2英雄梦之声_第18期_陈
2014/06/20 DOTA
Python中使用scapy模拟数据包实现arp攻击、dns放大攻击例子
2014/10/23 Python
Python字符串格式化的方法(两种)
2017/09/19 Python
浅析Python与Mongodb数据库之间的操作方法
2019/07/01 Python
基于TensorFlow常量、序列以及随机值生成实例
2020/01/04 Python
如何使用Python发送HTML格式的邮件
2020/02/11 Python
Python greenlet和gevent使用代码示例解析
2020/04/01 Python
Python3爬虫mitmproxy的安装步骤
2020/07/29 Python
Python3.8安装Pygame教程步骤详解
2020/08/14 Python
css3编写浏览器背景渐变背景色的方法
2018/03/05 HTML / CSS
电子专业自荐信
2014/07/01 职场文书
2014年学习部工作总结
2014/11/12 职场文书
服务明星事迹材料
2014/12/29 职场文书
初中毕业生自我评价
2015/03/02 职场文书
2015年公务员工作总结
2015/04/24 职场文书
男方家长婚礼致辞
2015/07/27 职场文书
Mysql MVCC机制原理详解
2021/04/20 MySQL