微信小程序获取时间(微信小程序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日期时间内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- 微信小程序计算器怎么用(微信小程序实现计算器功能)
- 聊天室python小程序(用Python写一个模拟qq聊天小程序的代码实例)
- uni app 小程序全局样式没法用(uniapp封装小程序雷达图组件的完整代码)
- html5带图标下拉菜单(html5小程序飞入购物车抛物线绘制运动轨迹点)
- 微信小程序企业微信打卡(使用Python实现企业微信的自动打卡功能)
- 小程序scroll-view自适应高度(小程序瀑布流解决左右两边高度差距过大的问题)
- 微信小程序可以用百度的echarts吗(uniapp在微信小程序中使用ECharts的方法)
- 微信小程序双人游戏横屏(微信小程序实现拼图游戏)
- 微信小程序如何请求服务器数据(微信小程序学习笔记之页面配置与路由方式)
- 小程序实现左右滑动窗口(小程序实现分页效果)
- 小程序ui设计样式(AmazeUI 平滑滚动效果的示例代码)
- 微信小程序计时器(微信小程序实现简单的计算器功能)
- 小程序数字化怎么布局(用position:sticky完美解决小程序吸顶问题的实现方法)
- python编写的小程序(几个适合python初学者的简单小程序,看完受益匪浅!推荐)
- thinkphp5开发小程序后台(PHP小程序支付功能完整版基于thinkPHP)
- 用python制作一个简单的小程序(一个可以套路别人的python小程序实例代码)
- 销 售 买 卖 你真的了解这四个字了吗(销售买)
- 谢娜是得罪快乐大本营造型师了吗 全场被黑化(谢娜是得罪快乐大本营造型师了吗)
- 前《iLOOK》时装总监 《快乐大本营》御用造型师上线(快乐大本营御用造型师上线)
- 释小龙晒杀青照片 多重身份惹观众期待(释小龙晒杀青照片)
- 《九牛之人降魔传》开机 演员祁高坤化身九牛之人除魔卫道(九牛之人降魔传开机)
- 王铲铲的致富之路无限金币卡法攻略教学(王铲铲的致富之路无限金币卡法攻略教学)
热门推荐
- 查看mysql支持的字符集(不可忽视的MySQL字符集)
- javascriptloop教程(JavaScript中的AOP编程的基本实现)
- 互联网云服务器需要配置(视频云服务器的配置一般怎么选?)
- dedecms如何使用标签(DEDECMS副栏目代码)
- numpy的核心是n维数组对象(利用ctypes获取numpy数组的指针方法)
- pyqt一键部署python环境(python使用PyQt5的简单方法)
- sql启动错误代码1814(SQLMSSQLSERVER服务启动错误代码3414的解决方法)
- css技巧100个(css小技巧汇总)
- js中toFixed() 的使用
- vuefor指令使用教程(Vue必学知识点之forEach的使用)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9