微信小程序——时间戳与Date对象的那些事

微信小程序——时间戳与Date对象的那些事,第1张

做过web开发的小伙伴们多少会遇到时间转换问题在Chrome浏览器和Safari浏览器的不同,报错或者时间格式等等,这里我就分享一下我在开发过程中遇到的一些问题

关于时间问题,做过日历的都知道,全球化时区处理,或者时间格式,裤链颤或者时间戳转化,这里我就这几种情况一一讨论

由于微信小程序的部分业务需要预定,所以会出现国外预定到国内时间会有偏差的问题,根本原因还是在于new Date(),它会获取当前系统时间,大部分手机是设置的是自动时间,所以会出现时区的偏差问题。

思考 :如果产品是某地的,那么预定时间应该为对应地的时区计算。所以需要维护定位与时区之间的关系

关于时区计算,因为我这边只用到了北京时间的情况,举个例子:

Safari浏览器中,进行 new Date("yyyy-MM-dd hh:mm:ss") 的时候,会出现报错Invalid Date,或者转换出问题的情况,原因是Safari并不支持此格式,所以需要调整格式化的方式。

ECMA-262 标准中( Date Time String Format )将日期格式规定为 YYYY-MM-DDTHH:mm:ss.sssZ ,其中, T 标识时间开始, Z 为唤侍相对于UTC(协调世界时 - International Atomic Time)的时间偏移量,可为 Z , +HH:mm 或 -HH:mm 。

思考 :要么正则替换为标准的 / 分割,要么在中间空白处加上 T ,看自己喜好

看文档是支持直接毫秒数时间戳转Date对象的,正常 *** 作也是如此。

PS :但是在微信小程序的iOS端胡败转过来的实际时间是UTC的时间,所以需要同步为当前时区时间,为了不影响Android的时间结果,所以通过转换2次的方式解决时间计算问题。

ECMA-262 标准来源参考: https://www.jianshu.com/p/a11196377048

在微信小程序中,可以利用 `setInterval()` 函数来实现长时间计时的功能。

具体步骤如下:

1. 在需要计时的页面或组件中定义一个计时器变量,如 `timer`,并初始化为 0。

2. 使用 `setInterval()` 函数,在一段时间间隔内执行一次指定的函数(比如每秒钟执行一次),并将返回值赋给计时器变量,如:

```

timer = setInterval(function() {

// 在这吵陪里编写计时器的逻辑

}, 1000)// 以毫秒为单位,表示每秒钟执行一次

```

3. 在计时器函数中编写计时器的逻辑,如:

```

var second = 0// 定义一个秒数变量

function timerFunction() {

second++// 每秒钟秒数加一

console.log("已经计时了 " + second + " 秒")

}

```

4. 当需要停止计时器时,可以使用 `clearInterval()` 函数消迹来清除计时器,如:

```

clearInterval(timer)// 停止计时器

```

完整示例代码:

```

var timer// 计时器变量

Page({

data: {

second: 0 // 秒数

},

onLoad: function () {

this.startTimer()// 页面加载时启动计时器

},

startTimer: function () {

var that = this

timer = setInterval(function() {

that.setData({

second: that.data.second + 1 // 每秒钟秒数加一

})

console.log("已经计时了 " + that.data.second + " 秒")

}, 1000)// 以毫秒为单位,表示每秒钟执行升桥蠢一次

},

stopTimer: function () {

clearInterval(timer)// 停止计时器

}

})

```


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12550530.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-26
下一篇 2023-05-26

发表评论

登录后才能评论

评论列表(0条)

保存