小程序實現(xiàn)列表多個批量倒計時
最近在寫一個列表功能,列表中有倒計時的效果,網(wǎng)上沒有可用的素材,以下是本人自己寫的,如有問題,希望大家指出。
先來看看基本的效果
小程序中列表倒計時,類似活動倒計時列表,列表中有多個倒計時效果,且不沖突
先把時間打印出來,放在data中,然后在寫計時器;如果先寫計時器,然后把打印出來的時間放在data就會報錯,setData不支持這種操作。
數(shù)據(jù)文件(dates.js,返回的時間數(shù)據(jù)是剩余時間)
var dates=[ { dat:324235235 }, { dat:7200000 }, { dat:675875754 } ] module.exports = { datetime: dates }
wxml文件(a.wxml)
<view wx:for="{{wearList.datetime}}" wx:for-item="item" wx:key="id"> <view class='dates'>{{item.difftime}}</view> </view>
js文件(a.js)
var dates=require('../utils/dates.js');//數(shù)據(jù)文件 Page({ data:{}, onShow(a){ // console.log(dates.datetime)//數(shù)據(jù) let that=this; let len=dates.datetime.length;//時間數(shù)據(jù)長度 function nowTime() {//時間函數(shù) // console.log(a) for (var i = 0; i < len; i++) { var intDiff = dates.datetime[i].dat;//獲取數(shù)據(jù)中的時間戳 // console.log(intDiff) var day=0, hour=0, minute=0, second=0; if(intDiff > 0){//轉換時間 day = Math.floor(intDiff / (60 * 60 * 24)); hour = Math.floor(intDiff / (60 * 60)) - (day * 24); minute = Math.floor(intDiff / 60) - (day * 24 * 60) - (hour * 60); second = Math.floor(intDiff) - (day * 24 * 60 * 60) - (hour * 60 * 60) - (minute * 60); if(hour <=9) hour = '0' + hour; if (minute <= 9) minute = '0' + minute; if (second <= 9) second = '0' + second; dates.datetime[i].dat--; var str=hour+':'+minute+':'+ second // console.log(str) }else{ var str = "已結束!"; clearInterval(timer); } // console.log(str); dates.datetime[i].difftime = str;//在數(shù)據(jù)中添加difftime參數(shù)名,把時間放進去 } that.setData({ wearList: dates }) // console.log(that) } nowTime(); var timer = setInterval(nowTime, 1000); } })
小程序中列表倒計時,類似活動倒計時列表,列表中有多個倒計時效果,且不沖突
先把時間打印出來,放在data中,然后在寫計時器;如果先寫計時器,然后把打印出來的時間放在data就會報錯,setData不支持這種操作。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JavaScript實現(xiàn)in-place思想的快速排序方法
這篇文章主要介紹了JavaScript實現(xiàn)in-place思想的快速排序方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-08-08通過JavaScript實現(xiàn)撲克牌游戲的示例代碼
這篇文章主要為大家詳細介紹了JavaScript如何通過面向對象實現(xiàn)一個簡單的撲克牌游戲,文中的示例代碼代碼講解詳細,感興趣的可以學習一下2022-07-07createElement動態(tài)創(chuàng)建HTML對象腳本代碼
利用createElement動態(tài)創(chuàng)建鏈接,div等代碼2008-11-11javascript 拷貝節(jié)點cloneNode()使用介紹
這篇文章主要介紹了javascript 節(jié)點操作拷貝節(jié)點cloneNode()的使用,需要的朋友可以參考下2014-04-04javascript實現(xiàn)點擊后變換按鈕顯示文字的方法
這篇文章主要介紹了javascript實現(xiàn)點擊后變換按鈕顯示文字的方法,可實現(xiàn)顯示一些按鈕如果點擊了,按鈕文本變?yōu)椤包c了”,其他按鈕文本變?yōu)椤皼]點”的效果,非常具有實用價值,需要的朋友可以參考下2015-05-05