亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

微信小程序在安卓的白屏問題原因及改進講解

2019-10-21 21:25:16
字體:
來源:轉載
供稿:網友

在做小程序的時候,做到了一個限時商品售賣,用到了倒計時,因為這個原因導致了安卓手機上使用小程序時,將小程序放入后臺運行一段時間后,再次進入小程序后出現了頁面白屏或者點擊事件失效的情況,這里記錄下

1.相關代碼文件

我這里是使用了自定義組件的形式來渲染的

  • 外部的引用的自定義組件的wxml文件
/* limitCommodity是一個數組,返回的是商品對象,包含商品價格、商品結束時間、商品圖片等 */<block wx:for="{{limitCommodity}}" wx:key="{{item.id}}">  <commodityItem class="specialContent" goods="{{item}}" /></block>
  • 自定義組件的js文件
Component({ properties: {  goods: Object }, data: { }, timer: null, /* 在組件實例進入頁面節點樹時執行,開始定時器 */ attached: function() {  if(this.timer) {   clearInterval(this.timer);  }  this.filterTime();  let that = this;    this.timer = setInterval(function () {   that.filterTime();  }, 1000) }, /* 在組件實例被從頁面節點樹移除時執行,將定時器清除 */ detached: function() {  clearInterval(this.timer);  this.timer = null; }, methods: {  /* 用于將時間戳轉換成自定義的時間格式 */  filterTime() {   let totalTime = new Date(parseInt(this.data.goods.endtime) * 1000) - new Date();   let days = parseInt(totalTime / 1000 / 60 / 60 / 24, 10);   let hours = parseInt(totalTime / 1000 / 60 / 60 % 24, 10);   let minutes = parseInt(totalTime / 1000 / 60 % 60, 10);   let seconds = parseInt(totalTime / 1000 % 60, 10);   let day = days >= 10 ? days : '0' + days;   day = day == 0 ? '' : day + '天';   let hour = hours >= 10 ? hours : '0' + hours;   let minute = minutes >= 10 ? minutes : '0' + minutes;   let second = seconds >= 10 ? seconds : '0' + seconds;   this.setData({    limitTime: day + hour + ":" + minute + ":" + second   })  }, }})

2.引起的原因

  • 因為在外部引入自定義的組件時,直接就是調用了定時器并且進行了setData操作,這就導致了當在外部引用這個組件時,如果傳入的商品數組長度較大時,定時器增多的同時,setData操作也不斷的增多
  • setData多了就會導致內存占用多

3.改進方法

改進方法就是減少setData操作

  • 可以再自定義一個組件,用于將整個數組傳入
  • 然后對商品數組里的時間先進行計算
  • 改進后的js文件
Component({ properties: {  limitCommodity:Array }, data: { }, timeOut:null, /* 在組件實例進入頁面節點樹時執行 */ attached(){  this.calculate(); }, /* 在組件實例被從頁面節點樹移除時執行,將定時器清除 */ detached(){  clearTimeout(this.timeOut);  this.timeOut = null; }, methods: {  filterTime(endtime) {   let totalTime = new Date(parseInt(endtime) * 1000) - new Date();   let days = parseInt(totalTime / 1000 / 60 / 60 / 24, 10);   let hours = parseInt(totalTime / 1000 / 60 / 60 % 24, 10);   let minutes = parseInt(totalTime / 1000 / 60 % 60, 10);   let seconds = parseInt(totalTime / 1000 % 60, 10);   let day = days >= 10 ? days : '0' + days;   day = day == 0 ? '' : day + '天';   let hour = hours >= 10 ? hours : '0' + hours;   let minute = minutes >= 10 ? minutes : '0' + minutes;   let second = seconds >= 10 ? seconds : '0' + seconds;   return day + hour + ":" + minute + ":" + second  },  calculate(){   let limitCommodity = this.data.limitCommodity;   for (let i = 0; i < limitCommodity.length;i++){    limitCommodity[i]['endtime_date'] = this.filterTime(limitCommodity[i]['endtime'])   }   this.setData({    limitCommodity   })   this.timeOut = setTimeout(()=>{    this.calculate();   },1000);  } }})

改進就是計算時間后再返回時間,而setData的是整個商品列表數組,這樣就減少了setData次數

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲va久久久噜噜噜久久天堂| 久久久在线观看| 欧美日韩国产精品一区二区不卡中文| 日韩精品久久久久久福利| 欧美猛交免费看| 国产午夜精品视频| 日本精品久久中文字幕佐佐木| 久久人人爽人人爽人人片亚洲| 亚洲男人的天堂网站| 91美女福利视频高清| 亚洲天堂av在线免费| 欧美华人在线视频| 久久91超碰青草是什么| 成人激情视频在线播放| 欧美福利视频网站| 欧美黄色片在线观看| 欧美性猛交xxxx免费看久久久| 成人网在线视频| 最好看的2019年中文视频| 中文日韩在线视频| 中国china体内裑精亚洲片| 日韩av电影手机在线观看| 日韩激情视频在线| 国产在线拍偷自揄拍精品| 欧美电影在线观看| 91精品啪aⅴ在线观看国产| 伦理中文字幕亚洲| 成人在线视频福利| 国产综合久久久久久| 97人洗澡人人免费公开视频碰碰碰| 久久99精品久久久久久青青91| 在线视频欧美日韩| 亚洲自拍中文字幕| 日韩电影免费在线观看中文字幕| 中文字幕成人精品久久不卡| 亚洲人成毛片在线播放| 成人精品久久一区二区三区| 国产日韩欧美日韩| 在线亚洲国产精品网| 深夜福利91大全| 国产精国产精品| 亚洲va久久久噜噜噜| 中文字幕日韩在线观看| 久久九九免费视频| 成人av在线网址| 久久久综合av| 欧美日韩在线视频一区二区| 日韩欧美国产一区二区| 亚洲欧美一区二区三区四区| 国产精品久久久久77777| 国产精品中文字幕久久久| 欧美激情第三页| 91精品国产综合久久久久久久久| 国产香蕉一区二区三区在线视频| 欧美专区在线视频| 亚洲摸下面视频| 全亚洲最色的网站在线观看| www.色综合| 日韩免费观看在线观看| 国产精品天天狠天天看| 琪琪亚洲精品午夜在线| 国产精品欧美日韩一区二区| 精品福利免费观看| 国内外成人免费激情在线视频网站| 亚洲精品色婷婷福利天堂| 国产精品久久久久久久久久久久久久| 亚洲综合精品伊人久久| 91av在线播放视频| 欧美激情a在线| 国产69精品99久久久久久宅男| 亚洲欧美自拍一区| 欧美乱大交做爰xxxⅹ性3| 色yeye香蕉凹凸一区二区av| 国产www精品| 大伊人狠狠躁夜夜躁av一区| 91爱爱小视频k| 国产一区二区色| 成人一区二区电影| 久久精品亚洲一区| 久久九九有精品国产23| 国外成人在线播放| 国产精品日韩在线观看| 亚洲一区二区三区视频| 91美女片黄在线观| 欧美中文在线观看国产| 亚洲精品中文字幕av| 九九热最新视频//这里只有精品| 欧美日韩xxxxx| 国产一区二区美女视频| 欧美午夜精品伦理| 91chinesevideo永久地址| 视频在线观看一区二区| 欧美激情亚洲另类| 亚洲国产精品高清久久久| 日韩毛片在线看| 欧美猛交ⅹxxx乱大交视频| 91精品国产自产91精品| 中文字幕视频在线免费欧美日韩综合在线看| 国产在线a不卡| 亚洲精品日韩久久久| 色偷偷9999www| 97精品免费视频| 国产日韩精品在线| 亚洲欧美日本精品| 自拍偷拍亚洲精品| 久久综合伊人77777蜜臀| 91中文字幕在线| 国产午夜精品全部视频在线播放| 久久成人免费视频| 欧美激情精品久久久久久变态| 精品国产一区av| 久久久久亚洲精品成人网小说| 欧美精品激情视频| 97香蕉久久超级碰碰高清版| 日韩av片电影专区| 一本大道香蕉久在线播放29| 欧美日本黄视频| 国产精品 欧美在线| 日韩国产欧美精品一区二区三区| 69av视频在线播放| 久久久亚洲成人| 日韩小视频在线观看| 欧美性猛交xxxx乱大交极品| 欧美中文在线视频| 欧美电影电视剧在线观看| 久久精品国产成人精品| xxxxx91麻豆| 欧美激情奇米色| 欧美一级黑人aaaaaaa做受| 国产精品视频一| 色综合伊人色综合网| 欧美一级黑人aaaaaaa做受| 91精品国产91久久久| 国产欧美精品xxxx另类| 国产女人精品视频| 亚洲欧美精品suv| 久热精品在线视频| 欧美乱妇高清无乱码| 中文字幕久热精品视频在线| 中文字幕亚洲欧美日韩在线不卡| 成人黄色av免费在线观看| 成人在线视频网站| 国产精品久久久久久亚洲调教| zzijzzij亚洲日本成熟少妇| 国产视频精品免费播放| 久久91亚洲人成电影网站| 清纯唯美亚洲激情| 日韩电影免费观看在线| 欧美一级电影免费在线观看| 成人字幕网zmw| 亚洲人成电影网站色| 一区二区亚洲精品国产| 久久99国产综合精品女同| 久久中文字幕一区| 日韩在线免费高清视频| 日韩中文在线视频| 97香蕉超级碰碰久久免费软件| 成人在线免费观看视视频| 91在线高清视频| 欧美激情一区二区三区高清视频| 亚洲人成网站999久久久综合| 日韩成人中文字幕在线观看| 日本高清视频一区| 26uuu国产精品视频|