在做小程序的时候,做到了一个限时商品售卖,用到了倒计时,因为这个原因导致了安卓手机上使用小程序时,将小程序放入后台运行一段时间后,再次进入小程序后出现了页面白屏或者点击事件失效的情况,这里记录下

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次数

正在努力学习中,若对你的学习有帮助,留下你的印记呗(点个赞咯^_^)

来源:https://segmentfault.com/a/1190000017478925

记一次微信小程序在安卓的白屏问题的更多相关文章

  1. 微信小程序iOS下拉白屏晃动,坑坑坑

    感觉ios的小程序每个页面都可以下拉出现白屏 有时页面带有滑动的属性会跟着晃动,体验不是很好 解决办法: 先禁止页面下拉 <config> { navigationBarTitleText ...

  2. 微信小程序、安卓APP、苹果APP对比分析

    今天的话题主要是关于微信小程序.安卓APP.苹果APP对比分析.既然是对比分析肯定是将它们一个一个说明. 本篇不涉及技术话题,只讲解微信小程序.安卓APP.苹果APP它们各自的优缺点及其应用场景. 一 ...

  3. 体验报告:微信小程序在安卓机和苹果机上的区别

    很多人可能会问:微信小程序和在微信里面浏览一个网页有什么区别? 首先,小程序的运行是全屏的,界面跟进入了一个APP很像,更为沉浸跟在微信里面访问h5不一样:其次,它的浏览体验更为稳定. 不过,这还不够 ...

  4. 记一次微信小程序开发

    之前在网上看到博客园新闻服务开放接口,因为自己本身有看博客园IT新闻的习惯,为了能随时随地简洁方便的浏览新闻,于是萌生了一个利用开放API开发一个微信小程序的想法. 1. mpvue初探 平时技术栈有 ...

  5. [开源硬件DIY] 自制一款精致炫酷的蓝牙土壤温湿度传感器,用于做盆栽呵护类产品(API开放,开发者可自行DIY微信小程序\安卓IOS应用)

    目录 前言: 1. 成品展示 2. 原理图解析 3. pcb设计 4. 嵌入式对外提供接口 4.1 蓝牙广播 4.2 蓝牙服务和属性 4.3 数据包格式 4.4 数据通信模型 重要 . 前言: 本期给 ...

  6. 微信小程序点击图片全屏

    作为一个只懂简单HTML,jQuery,JS的web后台开发者,最近在学习小程序开发,现在将小程序的点击全屏功能的相关内容记录下来.如果有不对的地方或者有更简单的方法,请留言指教 0_0~ .js 文 ...

  7. 记一次微信小程序的开发

    使用工具: 1.微信Web开发者工具 2.Visual Studio 2019 前端采用color UI,后端采用c# .net 过程中的几个重点点记录 1.color UI使用 下载colorUI以 ...

  8. 微信小程序学习记录(一)

    如何定义一个全局变量: 1,在根目录下app.js中添加 App({ globalData: { g_isPlayingMusic : false, g_currentMusicPostId :nul ...

  9. 微信小程序左右滑动切换页面示例代码--转载

    微信小程序——左右滑动切换页面事件 微信小程序的左右滑动触屏事件,主要有三个事件:touchstart,touchmove,touchend. 这三个事件最重要的属性是pageX和pageY,表示X, ...

随机推荐

  1. 警告: [SetContextPropertiesRule]{Context} Setting property 'source' to 'org.eclipse.jst.jee.server:esignmanage' did not find a matching property.解决

    1.开发环境: 环境:myeclipse2015+tomcat7+win10 2.异常: 偶尔在部署项目的时候回发现tomcat7部署后配置文件按照路径居然找不到自己的项目.httP://localh ...

  2. oracle 找回被覆盖的存储过程

    登录到sys账户下 1.TO_TIMESTAMP('2014-05-04 14:33:00', 'YYYY-MM-DD HH24:MI:SS') 删除前的日期 2.owner 表空调 3.Name   ...

  3. js对象动态赋值

    <view class="movies-template"> <template is="movieListTemplate" data=&q ...

  4. poj 2486 树形DP n选m连续路径

    题目连接:http://acm.hust.edu.cn/vjudge/problem/18071 资料连接: http://blog.csdn.net/woshi250hua/article/deta ...

  5. Spring课程 Spring入门篇 3-3 Spring bean装配(上)之aware接口

    课程链接: 本节主要介绍了以下内容: 1 aware介绍 2 代码演练 3 课程总结 1 aware介绍 1.1 为什么要使用aware? 在java类中,可以方便的获取xml配置文件中的bean的各 ...

  6. Python介绍以及Python环境搭建

    Python介绍以及Python环境搭建 1.Python 发展历史 Python是由Guido van Rossum在八十年代末和九十年代初,在荷兰国家数学和计算机科学研究所设计出来的,据说是在圣诞 ...

  7. Android 设置软键盘搜索键以及监听搜索键点击事件

    如图所示,有时候为了布局美观,在搜索时没有搜索按钮,而是调用软件盘上的按钮.调用的实现只需要在XML在输入框中加入android:imeOptions="actionSearch" ...

  8. SQLSERVER 2008 R2 事务日志已满

    方法一: USE [master] GO ALTER DATABASE DNName SET RECOVERY SIMPLE WITH NO_WAIT GO ALTER DATABASE DNName ...

  9. Struts2_HelloWorld_6

    为 eclipse 在编写 xml配置文件时提供提示,需要加上dtd或xls的标签定义文件的路径,具体操作: 1.Window——Preferences——XML Catalog 2.添加 dtd 文 ...

  10. ownCloud-9.1.1 (Ubuntu 16.04)

    平台: Ubuntu 类型: 虚拟机镜像 软件包: owncloud-9.1.1 commercial content management open-source owncloud storage ...