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 相关文章推荐
js function定义函数使用心得
Apr 15 Javascript
Textarea与懒惰渲染实现代码
Jan 04 Javascript
jquery ready(fn)事件使用介绍
Aug 21 Javascript
实用框架(iframe)操作代码
Oct 23 Javascript
jQuery插件简单实现方法
Jul 18 Javascript
JS的框架Polymer中的dom-if和is属性使用说明
Jul 29 Javascript
js阻止浏览器默认行为触发的通用方法(推荐)
May 15 Javascript
详解JavaScript中this关键字的用法
May 26 Javascript
jQuery实现最简单的切换图效果【可兼容IE6、火狐、谷歌、opera等】
Sep 04 Javascript
微信小程序 缓存(本地缓存、异步缓存、同步缓存)详解
Jan 17 Javascript
基于vue-cli npm run build之后vendor.js文件过大的解决方法
Sep 27 Javascript
vue-cli3项目配置eslint代码规范的完整步骤
Sep 10 Javascript
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 运行效率总结(提示程序速度)
2009/11/26 PHP
php中数字0和空值的区别分析
2014/06/05 PHP
php简单实现MVC
2015/02/05 PHP
PHP模板引擎Smarty自定义变量调解器用法
2016/04/11 PHP
php封装的page分页类完整实例
2016/10/18 PHP
PHP中$GLOBALS与global的区别详解
2019/03/21 PHP
javascript Split方法,indexOf方法、lastIndexOf 方法和substring 方法
2009/03/21 Javascript
jQuery html()等方法介绍
2009/11/18 Javascript
鼠标放在图片上显示大图的JS代码
2013/03/26 Javascript
JavaScript时间转换处理函数
2015/04/14 Javascript
jQuery+Ajax实现无刷新分页
2015/10/30 Javascript
jQuery实例—选项卡的简单实现(js源码和jQuery)
2016/06/14 Javascript
JSP防止网页刷新重复提交数据的几种方法
2016/11/19 Javascript
vue使用axios实现文件上传进度的实时更新详解
2017/12/20 Javascript
JS中的回调函数实例浅析
2018/03/21 Javascript
详解Axios统一错误处理与后置
2018/09/26 Javascript
vue-cli 打包后提交到线上出现 &quot;Uncaught SyntaxError:Unexpected token&quot; 报错
2018/11/06 Javascript
JavaScript算法学习之冒泡排序和选择排序
2019/11/02 Javascript
node.js中Buffer缓冲器的原理与使用方法分析
2019/11/23 Javascript
ubuntu安装sublime3并配置python3环境的方法
2018/03/15 Python
python函数参数(必须参数、可变参数、关键字参数)
2019/08/16 Python
PyCharm安装PyQt5及其工具(Qt Designer、PyUIC、PyRcc)的步骤详解
2020/11/02 Python
python二维图制作的实例代码
2020/12/03 Python
英国No.1文具和办公用品在线:Euroffice
2016/09/21 全球购物
英国床垫和床架购物网站:Bedman
2019/11/04 全球购物
EM Cosmetics官网:由彩妆大神Michelle Phan创办的独立品牌
2020/04/27 全球购物
如何将无状态会话Bean发布为WEB服务,只有无状态会话Bean可以发布为WEB服务?
2015/12/03 面试题
校长先进事迹材料
2014/02/01 职场文书
校园文明倡议书
2014/05/16 职场文书
学校花圃的标语
2014/06/18 职场文书
物流专业求职信
2014/06/30 职场文书
企业员工爱岗敬业演讲稿
2014/08/26 职场文书
车间主任岗位职责范本
2015/04/08 职场文书
小组口号霸气押韵
2015/12/24 职场文书
浅谈Golang 切片(slice)扩容机制的原理
2021/06/09 Golang
Win10加载疑难解答时出错发生意外错误的解决方法
2022/07/07 数码科技