文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue如何实现同时设置多个倒计时

2023-06-15 04:12

关注

这篇文章主要介绍vue如何实现同时设置多个倒计时,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

具体内容如下

html如下:

<div class="home">    <tbody>      <tr v-for="(item, index) in bargainGoods" :key="index">        <td v-text="item.down + Djs_timeList(item.countDown)"></td>      </tr>    </tbody></div>

js如下:

export default {  data() {    return {      bargainGoods: [],      total: 0,      page: 1,      serverTime: 0,      timer: ""      // hostUrl: this.$hostUrl    };  },  //用于数据初始化  created: function() {    // 获取数据    this.goods();    // 获取服务器时间    this.findServiceTime();  },  methods: {    goods: function() {      var _this = this;      _this.$axios({        url: "goods/pageGoods",        data: {          current: -1,          activityStatus: "",          limit: -1,          status: "SALE"        },        success: response => {          _this.bargainGoods = response.items;          _this.Djs_time();// 调用定时器          //  以下是我处理的后台返回数据   开始时间和结束时间,页面显示用的          if (_this.bargainGoods.length != 0) {            for (var key in _this.bargainGoods) {              var hour = 0;              var startime = 0;              if (_this.bargainGoods[key] != null) {                _this.bargainGoods[key].countDown = "";                _this.bargainGoods[key].down = "";                // 结束时间                hour = _this.bargainGoods[key].overTime;                startime = _this.bargainGoods[key].activityStartTime;                hour = hour.replace(/-/g, "/");                hour = new Date(hour).getTime();                startime = startime.replace(/-/g, "/");                startime = new Date(startime).getTime();                // 如果结束时间大于当前时间                if (hour > _this.serverTime && startime < _this.serverTime) {                  var hourtime = hour - _this.serverTime;                  if (hourtime > 0) {                    _this.bargainGoods[key].down = "结束倒计时:";                    _this.bargainGoods[key].countDown =                      _this.bargainGoods[key].overTime;                  }                } else if (startime > _this.serverTime) {                  var starhourtime = startime - _this.serverTime;                  if (starhourtime > 0) {                    _this.bargainGoods[key].down = "开始倒计时:";                    _this.bargainGoods[key].countDown =                      _this.bargainGoods[key].activityStartTime;                  }                } else {                  _this.bargainGoods[key].down = "已结束";                  _this.bargainGoods[key].countDown = "";                }                // console.log(_this.bargainGoods);              }            }            _this.bargainGoods = _this.bargainGoods;          }        }      });    },    // 获取服务器时间    findServiceTime() {      var _this = this;      _this.$axios({        url: "serverTime/getDateTime",        success: function(res) {          _this.serverTime = res.item;        }      });    },    Djs_time: function() {      this.timer = setInterval(() => {        this.serverTime = this.serverTime + 1000;      }, 1000);    },    Djs_timeList: function(itemEnd) {      //  此处 itemEnd 的日期是年月日时分秒      var endItem = new Date(itemEnd).getTime(); //获取列表传的截止时间,转成时间戳      var nowItem = this.serverTime; //获取当前时间      var rightTime = endItem - nowItem; //截止时间减去当前时间      if (rightTime > 0) {        //判断剩余倒计时时间如果大于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);        var showTime = dd + "天" + hh + "小时" + mm + "分" + ss + "秒";      } else {        var showTime = "";      }      return showTime;    },  },    //离开页面后清除定时器  destroyed() {    clearInterval(this.timer);  }};

效果如下:

vue如何实现同时设置多个倒计时

为什么要使用Vue

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以创建可维护性和可测试性更强的代码库,Vue允许可以将一个网页分割成可复用的组件,每个组件都包含属于自己的HTML、CSS、JavaScript,以用来渲染网页中相应的地方,所以越来越多的前端开发者使用vue。

以上是“vue如何实现同时设置多个倒计时”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯