微信小程序过滤器之计算当前时间差

微信小程序过滤器之计算当前时间差


前言

最近遇到了一个需求,将小程序里面的具体时间2023-12-11 09:41:06 转为当前时间差10小时前,这块可以使用js逻辑函数对数据进行处理,但这里我们采用微信小程序里面的过滤器wxs来进行处理。

一、wxs简介

不同于vue2里面的filter函数,微信小程序里面给出的是wxs,;

wxs(WeiXin Script) 是小程序独有的一套脚本语言,结合wxml,可以构建出页面的结构。wxml中无法调用在页面的js中定义的函数,但是wxml可以调用wxs中定义的函数,因此,小程序中wxs的典型应用场景是'过滤器

二、使用步骤

1.定义

创建一个wxs后缀的文件,里面定义一个函数timago(目前不支持es6语法),然后在下面的module.exports部分导出即可,前者是键名,后者是值名(可根据需求修改);

在wxs里面不支持new Date()函数,因此使用getDate()获取当前时间。

javascript 复制代码
//计算时间差函数
var timeago = function (dateTimeStamp) {
	var dateTimeStamp=getDate(dateTimeStamp).getTime()
	var minute = 1000 * 60;      //时间用毫秒表示
	var hour = minute * 60;
	var day = hour * 24;
	var week = day * 7;
	var month = day * 30;
	var now = getDate().getTime();   //当前时间毫秒
	var passTime = now - dateTimeStamp;//过了多少毫秒
	if (passTime < 0) { return; }
	var aminute = passTime / minute;
	var ahour = passTime / hour;
	var aday = passTime / day;
	var aweek = passTime / week;
	var amonth = passTime / month;
	var result = '';
	if (amonth >= 1) {
		result = "" + parseInt(amonth) + "月前";
	} else if (aweek >= 1) {
		result = "" + parseInt(aweek) + "周前";
	} else if (aday >= 1 && aday < 7) {
		console.log("" + parseInt(aday) + "天前")
		result = "" + parseInt(aday) + "天前";
	} else if (ahour >= 1 && ahour < 24) {
		result = "" + parseInt(ahour) + "小时前";
	} else if (aminute >= 1 && aminute < 60) {
		result = "" + parseInt(aminute) + "分钟前";
	} else if (aminute < 1) {
		result = "刚刚";
	} else {
		result = ""
	}
	return result;
}

module.exports = {
	timeago: timeago,
};

2.使用

在wxml文件引用刚刚定义的wxs文件,如下所示,src为文件存放的路径,module为使用的模块名

html 复制代码
<wxs src='/utils/filter.wxs' module='filter' />

如下,将js中的变量进行处理

html 复制代码
<view>{{filter.timeago(time)}}</view>

结果对比

相关推荐
qq_12498707532 小时前
基于SpringBoot微信小程序的智能在线预约挂号系统(源码+论文+部署+安装)
spring boot·后端·微信小程序·毕业设计·计算机毕设·毕业设计源码
程序媛徐师姐3 小时前
Java基于SSM的即时空教室查询小程序,附源码+文档说明
java·微信小程序·小程序·ssm·即时空教室查询小程序·java即时空教室查询小程序·即时空教室查询微信小程序
Dragon Wu5 小时前
Taro Webpack 5 编译过慢的解决方案
前端·webpack·小程序·taro
吴声子夜歌6 小时前
小程序——界面API(一)
java·javascript·小程序
小小王app小程序开发7 小时前
场馆预约小程序核心玩法拆解与技术落地分析
小程序
qq_12498707537 小时前
基于springboot的微信小程序的博物馆文创系统的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·spring·微信小程序·毕业设计·计算机毕设
吴声子夜歌7 小时前
小程序——文件上传和下载
小程序
计算机徐师兄7 小时前
Java基于微信小程序的社区垃圾回收管理系统【附源码、文档说明】
java·微信小程序·社区垃圾回收管理系统·社区垃圾回收管理系统小程序·社区垃圾回收管理微信小程序·社区垃圾回收管理小程序·jav社区垃圾回收管理小程序
CHU7290358 小时前
便捷点餐,随心畅享——外卖点餐小程序前端功能详解
前端·小程序
2501_916008898 小时前
iPhone 上怎么抓 App 的网络请求,在 iOS 设备上捕获网络请求
android·网络·ios·小程序·uni-app·iphone·webview