微信小程序页面使用类似filter函数的wxs语法

在vue框架中,页面上我们展示有些信息的时候,数据有的是从后台返回的,格式相对固定,有些数据还需要我们做个翻译,比如一些状态1/0,我们展示在页面的时候,显示"成功""失败"。还有一些枚举类的值,我们也需要做一个简单的转化,在vue框架里面,我们可以使用过滤器这样的方式,比如:

{{name | toUpperCase()}}

这个方法就是把名字中的字母转大写。虽然这个功能也可以在获取数据的时候,我们通过js代码直接转化,可是通过过滤器的方式,很直观,代码侵入少。

在微信小程序开发这里,也有这样的功能,不过它的使用和过滤器有些区别。微信小程序这里叫wxs语法,转换的代码需要写在wxs代码块内。

wxs语法不同于一般的javascript语法。无法使用es5语法,变量统一使用var声明。不能使用let,const关键字。

另外一个值得关注的地方,关于日期转化,一般而言,我们日期在后台传过来之后,变成一个字符串,这时候,需要格式化,需要先把它变为一个日期对象,wxs语法里面没有new Date()这样的用法,它直接转日期,有一个javascript方法里面没有的方法getDate()。这个是一个大坑。

一般为了简单,直接把wxs代码块放在wxml页面内,如下是一个日期简单转化的方法。

javascript 复制代码
<wxs module="pagefilter">
  var formatDate = function(date) {
    var newDate = getDate(date)
    var year = newDate.getFullYear()
    var month = newDate.getMonth() + 1
    var day = newDate.getDate()
    return year + "-" + month + "-" + day
  }
  module.exports = {
    formatDate: formatDate
  }
</wxs>

页面上使用的时候:

html 复制代码
<view>{{pagefilter.formatDate(expireDate)}}</view>

这个语法和vue中filter用法不一样,需要modulename.exportsmethod的方式调用。

上面方法中getDate()方法就是把字符串格式日期转日期对象格式,在wxs语法中就有效,javascript语法中却没有这个方法:

所以这里是一个大坑,我们在wxs语法中,可以使用大量的javascript语法,可是,new Date(),new RegExp()这样的就无法使用。

相关推荐
30767 小时前
uni-app在微信小程序国际化分包方案:优雅解决主包体积超限问题
微信小程序
文慧的科技江湖12 小时前
光储充一体化开源能源管理系统 需求说明书(简单版) - 慧知开源充电桩平台
小程序·开源·能源·光储充·光伏系统·实现光储充全设备统一监控·光储充一体化开源能源管理系统
eric*168814 小时前
Mac反编译小程序教程
小程序·小程序反编译
打瞌睡的朱尤15 小时前
微信小程序50~75
微信小程序·小程序
ZC跨境爬虫15 小时前
【零基础实战】Fiddler抓取PC微信小程序数据流,爬取华为商城商品配置+真实评论(完整可运行代码+逐行解析)
测试工具·微信小程序·fiddler
weixin_3947580319 小时前
直播间小程序码生成问题修复代码清单
android·小程序·apache
程序鉴定师2 天前
上海本凡科技解密小程序开发公司的价格构成与市场价值
大数据·小程序
hnxaoli2 天前
win10小程序(十九)鼠标位置记录
python·小程序
IT观测2 天前
# 2026年SaaS小程序制作平台对比:乔拓云、有赞、微盟
小程序
宁夏雨科网2 天前
印刷包装公司开发小程序的优势与内容
小程序·展示小程序·印刷包装·印刷公司小程序