vue實(shí)現(xiàn)列表倒計(jì)時(shí)
本文實(shí)例為大家分享了vue實(shí)現(xiàn)列表倒計(jì)時(shí)的具體代碼,供大家參考,具體內(nèi)容如下
如圖10分鐘倒計(jì)時(shí)

在做項(xiàng)目的時(shí)候遇到vue列表要用到倒計(jì)時(shí)的方法,想直接在頁(yè)面中處理,使用vue過濾器。
<!DOCTYPE html>
<html>
<head>
?? ?<meta charset="utf-8">
? ? <meta name="viewport" content="maximum-scale=1.0,minimum-scale=1.0,user-scalable=0,width=device-width,initial-scale=1.0"/>
? ? <meta name="format-detection" content="telephone=no,email=no,date=no,address=no">
? ? <title>倒計(jì)時(shí)</title>
? ? <link rel="stylesheet" type="text/css" href="../css/css2021.css" />
? ? <style>
? ? ? ? #app{
? ? ? ? ?? ?min-height:100vh;
? ? ? ? }
? ? ? ? .doglist{
? ? ? ? ?? ?width:93.6vw;margin:0 auto;
? ? ? ? }
? ? ? ? .dogli{
? ? ? ? ?? ?margin-bottom:2.7vw;border-radius:2vw;
? ? ? ? }
? ? ? ? .userimg{
? ? ? ? ? ? width:26vw;height:26vw;border-radius:2vw;margin:1.33vw;
? ? ? ? }
? ? ? ? .userimg .imgs{border-radius:2vw;}
? ? ? ? .userinfo{width:62vw;height:26vw;}
? ? ? ? .leftbox{height:20vw;}
? ? </style>
</head>
<body>?
<div id="app" class="bg-f9f9f9 f-3-7 c-333">
? ? <div class="doglist">
? ? ? ? <div class="dogli align-center bg-fff" v-for="(vo,index) in list" :key="index">
? ? ? ? ? ? <div class="userimg">
? ? ? ? ? ? ? ? <img :src=vo.userimg alt="" class="imgs">
? ? ? ? ? ? </div>
? ? ? ? ? ? <div class="userinfo space-center">
? ? ? ? ? ? ? ? <div class="leftbox flex-column-space f-w-b">
? ? ? ? ? ? ? ? ? ? <div class="username line-overflow1 f-4">{{vo.name}}</div>
? ? ? ? ? ? ? ? ? ? <div class="prices">¥{{vo.price}}</div>
? ? ? ? ? ? ? ? </div>
? ? ? ? ? ? ? ? <div class="times">{{vo.time | limitTimeFilter}}</div>
? ? ? ? ? ? </div>
? ? ? ? </div>
? ? </div>
</div>
</body>
<script type="text/javascript" src="../script/vant/vue.js"></script>
<script type="text/javascript" src="../script/main.js"></script>
<script type="text/javascript" src="../script/fastclick.js"></script>
<script type="text/javascript">
?? ?// 初始化fastclick方法
? ? window.addEventListener('load', function () {
? ? ? ? FastClick.attach(document.body);
? ? }, false);
? ? var vm = new Vue({
?? ??? ?el:'#app',
?? ??? ?data:{
? ? ? ? ? ? list:[
? ? ? ? ? ? ? ? {"id":1,"name":"多多","add_time":"1645577937","userimg":"../image/dog1.jpg","price":"1200"},
? ? ? ? ? ? ? ? {"id":2,"name":"laughing","add_time":"1645577967","userimg":"../image/dog2.jpg","price":"1600"},
? ? ? ? ? ? ? ? {"id":3,"name":"饅頭","add_time":"1645577997","userimg":"../image/1.jpeg","price":"600"},
? ? ? ? ? ? ? ? {"id":4,"name":"團(tuán)團(tuán)","add_time":"1645577988","userimg":"../image/2.jpeg","price":"400"},
? ? ? ? ? ? ],
? ? ? ? ? ? ticker:null,
?? ??? ?},
? ? ? ? filters:{
? ? ? ? ? ? //倒計(jì)時(shí)10分鐘
? ? ? ? ? ? limitTimeFilter (val) {
? ? ? ? ? ? ? ? var rightTime = val;
? ? ? ? ? ? ? ? var showTime = '';
? ? ? ? ? ? ? ? if (rightTime > 0) {
? ? ? ? ? ? ? ? ? ? //判斷剩余倒計(jì)時(shí)時(shí)間如果大于0就執(zhí)行倒計(jì)時(shí)否則就結(jié)束
? ? ? ? ? ? ? ? ? ? var dd = Math.floor(rightTime / 60 / 60 / 24) < 10 ? '0' + Math.floor(rightTime / 60 / 60 / 24) : Math.floor(rightTime / 60 / 60 / 24);
? ? ? ? ? ? ? ? ? ? var hh = Math.floor((rightTime / 60 / 60) % 24) < 10 ? '0' + Math.floor((rightTime / 60 / 60) % 24) : Math.floor((rightTime / 60 / 60) % 24);
? ? ? ? ? ? ? ? ? ? var mm = Math.floor((rightTime / 60) % 60) < 10 ? '0' + Math.floor((rightTime / 60) % 60) : Math.floor((rightTime / 60) % 60);
? ? ? ? ? ? ? ? ? ? var ss = Math.floor((rightTime) % 60) < 10 ? '0' + Math.floor((rightTime) % 60) : Math.floor((rightTime) % 60);
? ? ? ? ? ? ? ? ? ? if(dd>0){
? ? ? ? ? ? ? ? ? ? ? ? showTime = `剩余${dd}天${hh}時(shí)${mm}分${ss}秒`
? ? ? ? ? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? ? ? ? ? if(hh>0){
? ? ? ? ? ? ? ? ? ? ? ? ? ? showTime = `剩余${hh}時(shí)${mm}分${ss}秒`
? ? ? ? ? ? ? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? ? ? ? ? ? ? if(mm>0){
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? showTime = `剩余${mm}分${ss}秒`
? ? ? ? ? ? ? ? ? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if(ss>0){
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? showTime = `剩余${ss}秒`
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? var showTime = "";
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? return showTime;
? ? ? ? ? ? } ?? ?
? ? ? ? },
? ? ? ? mounted() {
? ? ? ? ? ? //這一段是防止進(jìn)入頁(yè)面出去后再進(jìn)來(lái)計(jì)時(shí)器重復(fù)啟動(dòng)
? ? ? ? ? ? if (this.ticker) {
? ? ? ? ? ? ? ? clearInterval(this.ticker);
? ? ? ? ? ? }
? ? ? ? ? ? this.beginTimer();
? ? ? ? },
?? ??? ?methods:{
? ? ? ? ? ? beginTimer() { //這個(gè)計(jì)時(shí)器是每秒減去數(shù)組中指定字段的時(shí)間
? ? ? ? ? ? ? ? this.ticker = setInterval(() => {
? ? ? ? ? ? ? ? ? ? for (let i = 0, len = this.list.length; i < len; i++) {
?? ? ? ? ? ? ? ? ? ? ? ?var obj = this.list[i];
?? ? ? ? ? ? ? ? ? ? ? ?obj.time--;
?? ? ? ? ? ? ? ? ? ? ? ?this.$set(this.list,i,obj)//給list賦值
?? ? ? ? ? ? ? ? ? ? ? ?if(obj.time<1){
?? ? ? ? ? ? ? ? ? ? ? ? ? ?clearInterval(this.ticker);
?? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }, 1000);
? ? ? ? ? ? },
? ? ? ? ? ? get_list(){
? ? ? ? ? ? ?? ?//獲取time
? ? ? ? ? ? ?? ?vm.list.forEach(function(el){
? ? ? ? ? ? ? ? ? ? ?el.time=el.add_time*1+600 - Date.parse(new Date())/1000;//頁(yè)面上要顯示的結(jié)束時(shí)間
? ? ? ? ? ? ? ? ? ? ?vm.list.push(el);
? ? ? ? ? ? ? ? });
? ? ? ? ? ? },
?? ??? ?}
?? ?})
?? ?apiready = function(){
? ? ? ? vm.get_list()
?? ?};
? ??
</script>
</html>以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Vue3?實(shí)現(xiàn)驗(yàn)證碼倒計(jì)時(shí)功能
- Vue3?實(shí)現(xiàn)驗(yàn)證碼倒計(jì)時(shí)功能(刷新保持狀態(tài))
- vue實(shí)現(xiàn)點(diǎn)擊按鈕倒計(jì)時(shí)
- Vue實(shí)現(xiàn)倒計(jì)時(shí)小功能
- vue實(shí)現(xiàn)驗(yàn)證碼倒計(jì)時(shí)按鈕
- vue實(shí)現(xiàn)時(shí)間倒計(jì)時(shí)功能
- vue實(shí)現(xiàn)同時(shí)設(shè)置多個(gè)倒計(jì)時(shí)
- Vue倒計(jì)時(shí)3秒后返回首頁(yè)Demo(推薦)
相關(guān)文章
vue 中 element-ui table合并上下兩行相同數(shù)據(jù)單元格
這篇文章主要介紹了vue 中 element-ui table合并上下兩行相同數(shù)據(jù)單元格,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12
elementUI中input回車觸發(fā)頁(yè)面刷新問題與解決方法
這篇文章主要給大家介紹了關(guān)于elementUI中input回車觸發(fā)頁(yè)面刷新問題與解決方法,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用elementUI具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-07-07
vue打包更新packge.json版本號(hào)的全過程
這篇文章主要介紹了vue打包更新packge.json版本號(hào)的全過程,文章通過圖文結(jié)合的方式給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-08-08
Vue?keepAlive實(shí)現(xiàn)不同的路由共用一個(gè)組件component的緩存問題(推薦)
這篇文章主要介紹了Vue?keepAlive實(shí)現(xiàn)不同的路由共用一個(gè)組件component的緩存問題,實(shí)現(xiàn)方式使用Vue?keepAlive實(shí)現(xiàn)頁(yè)面緩存,需要的朋友可以參考下2022-08-08
解決axios發(fā)送post請(qǐng)求返回400狀態(tài)碼的問題
今天小編就為大家分享一篇解決axios發(fā)送post請(qǐng)求返回400狀態(tài)碼的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-08-08
Vue?Router動(dòng)態(tài)路由實(shí)現(xiàn)實(shí)現(xiàn)更靈活的頁(yè)面交互
Vue?Router是Vue.js官方的路由管理器,用于構(gòu)建SPA(單頁(yè)應(yīng)用程序),本文將深入探討Vue?Router的動(dòng)態(tài)路由功能,希望可以幫助大家更好地理解和應(yīng)用Vue.js框架2024-02-02
在Nginx上部署前端Vue項(xiàng)目的詳細(xì)步驟(超級(jí)簡(jiǎn)單!)
這篇文章主要介紹了在Nginx上部署前端Vue項(xiàng)目的詳細(xì)步驟,Nginx是一款高效的HTTP和反向代理Web服務(wù)器,作為開源軟件,Nginx以其高性能、可擴(kuò)展性和靈活性廣泛應(yīng)用于Web架構(gòu)中,文中將步驟介紹的非常詳細(xì),需要的朋友可以參考下2024-10-10

