微信小程序获取时间(微信小程序wxs日期时间处理的实现示例)
类别:编程学习 浏览量:1901
时间:2021-10-08 00:47:12 微信小程序获取时间
微信小程序wxs日期时间处理的实现示例目录
- 1、时间戳转日期
- 2、UTC转北京时间
WXS(WeiXin Script)是小程序的一套脚本语言,wxs 与 javascript 是不同的语言,有自己的语法,并不和 javascript 一致。其中包括了很多日常使用的javascript函数,在wxs中都是不能同样使用的。最近在做一个列表的时候,涉及到时间格式化操作。就遇到了这个问题,以前写好了的格式化工具函数直接拷贝到小程序项目的wxs文件中,函数不能正常执行。其中包括了下面的几个错误
- 正则表达式在字符串的replace函数中的使用方法不一样,不能直接使用var a = /[0-9]/这种方式声明使用。正确的方式为var reg = getRegExp("-", “g”);
- 获取当前时间不能通过new Date()获取,而是通过getDate方法获取。
- getDate(‘2018/12/12')可以获取对应日期的date类型的时间。
在wxs中处理日期需要使用getDate(time),而不能使用new Date()来处理日期
在wxs文件中
var filter = { formatNumber: function (n) { n = n.toString() return n[1] ? n : '0' + n }, parseTime: function (time, type) { if (time == null || type == '') { return '' } if (arguments.length === 0) { return null } var date = getDate(time);//在wxs中不能使用new Date()来处理日期 console.log("date", date); var y = date.getFullYear(); var m = filter.formatNumber(date.getMonth() + 1); var d = filter.formatNumber(date.getDate()); var h = filter.formatNumber(date.getHours()); var i = filter.formatNumber(date.getMinutes()); var s = filter.formatNumber(date.getSeconds()); var a = filter.formatNumber(date.getDay()); var time_str = ""; if (type == 'month') { time_str = y + '-' + m; } else if (type == 'date') { time_str = y + '-' + m + '-' + d; } else if (type == 'datetime') { time_str = y + '-' + m + '-' + d + ' ' + h + ':' + i + ':' + s; } else if (type == 'onlyMonth') { time_str = m; } else if (type == 'onlyYear') { time_str = y; } return time_str }, } module.exports = { parseTime: filter.parseTime, }
在wxml中使用
<wxs module="filters" src="../../../filters/filter.wxs"></wxs> <text>{{filters.parseTime(time,'date')}}</text>
UTC时间比北京时间晚8小时,在苹果手机上需要去除"Z"后再处理时间
var filter = { formatNumber: function (n) { n = n.toString() return n[1] ? n : '0' + n }, parseTime: function (time, type) { if (time == null || time == '') { return '' } if (arguments.length === 0) { return null } var date; if (typeof time === 'object') { date = time } else { if (('' + time).length === 10) { time = parseInt(time) * 1000 } else { time = time.replace("Z", " ").replace(getRegExp('-', 'g'), "/")//去除Z,兼容苹果手机 var ts = time.split('T') var t1 = ts[0] var t2 = ts[1].split('.')[0] time = t1 + " " + t2 time = getDate(time).getTime() + 8 * 3600000;//utc时间与北京时间相差8小时 } date = getDate(time)//不能使用new Date() } var y = date.getFullYear(); var m = filter.formatNumber(date.getMonth() + 1); var d = filter.formatNumber(date.getDate()); var h = filter.formatNumber(date.getHours()); var i = filter.formatNumber(date.getMinutes()); var s = filter.formatNumber(date.getSeconds()); var a = filter.formatNumber(date.getDay()); var time_str = ""; if (type == 'month') { time_str = y + '-' + m; } else if (type == 'date') { time_str = y + '-' + m + '-' + d; } else if (type == 'datetime') { time_str = y + '-' + m + '-' + d + ' ' + h + ':' + i + ':' + s; } else if (type == 'onlyMonth') { time_str = m; } else if (type == 'onlyYear') { time_str = y; } return time_str }, } module.exports = { parseTime: filter.parseTime, }
到此这篇关于微信小程序 wxs日期时间处理的实现示例的文章就介绍到这了,更多相关小程序 wxs日期时间内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- 微信小程序存token(小程序开发实现access_token统一管理)
- 微信小程序苹果部分内容打不开(微信小程序audio组件在ios端无法播放的解决办法)
- 小程序ui图与移动ui(AmazeUI 缩略图的实现示例)
- 微信小程序引用模板的函数(微信小程序页面与组件之间信息传递与函数调用)
- ih5如何点击按钮跳转至网页(HTML5跳转小程序wx-open-launch-weapp的示例代码)
- python抽奖代码教程(python实现抽奖小程序)
- 微信小程序可以用百度的echarts吗(uniapp在微信小程序中使用ECharts的方法)
- php关注公众号发送消息(php实现QQ小程序发送模板消息功能)
- 微信小程序静态页面详情(微信小程序基础教程之echart的使用)
- 微信小程序canvas 动画(微信小程序使用canvas绘制钟表)
- vue实现商品详情讲解(京东 Vue3 组件库支持小程序开发的详细流程)
- 微信小程序简易计算器制作(微信小程序实现简单计算器功能)
- 微信小程序css使用技巧(微信小程序 CSS filter滤镜的使用示例详解)
- 小程序ui设计样式(AmazeUI 平滑滚动效果的示例代码)
- 微信小程序日期选择器有星期天(微信小程序 滚动选择器时间日期详解及实例代码)
- 微信小程序双人游戏横屏(微信小程序实现拼图游戏)
- 人从众 火炎焱 全椒再现 正月十六走太平 的魅力(人从众火炎焱全椒再现)
- 官宣 全椒籍明星许海峰 奚秀兰 方芳 王璐瑶携手回家 走太平(全椒籍明星许海峰)
- 以前全椒人是怎么过冬的 满满都是回忆(以前全椒人是怎么过冬的)
- NVIDIA显卡份额冲上88 A饭发愁 游戏优化恐没A卡份了(NVIDIA显卡份额冲上88A饭发愁)
- AMD YES A卡还是N卡 A卡和N卡的区别(AMDYESA卡还是N卡)
- 以后显卡多了一个新选择,N卡和A卡外又多了个I卡(以后显卡多了一个新选择)
热门推荐
- mysql分库分表视图(MySQL分库分表与分区的入门指南)
- windows服务器安装宝塔面板(云服务器无法安装宝塔面板及软件解决方案)
- canvas 绘图解决方案(高清屏下canvas重置尺寸引发的问题的解决)
- zabbix怎么监控数据库(使用zabbix监控oracle表空间的操作流程)
- mysql总是报错error(MySQL 5.6主从报错的实战记录)
- laravel视图组件(Laravel5.4框架中视图共享数据的方法详解)
- thinkphp分页效果怎样(thinkphp5+layui实现的分页样式示例)
- laravel在中间件内生成参数并且传递到控制器中的2种姿势(laravel在中间件内生成参数并且传递到控制器中的2种姿势)
- mysql的count知识(MySQL中MTR的概念)
- mysql恢复数据库(MySQL 两种恢复数据的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9