mPaas小程序(支付宝、钉钉...)页面中(axml中)使用函数(使用.sjs文件)

本文介绍了在MPAAS小程序中,由于JavaScript函数在页面中调用可能出现问题,因此建议使用SJS(Safe/Subset JavaScript)来定义函数。通过示例展示了如何在.sjs文件中定义一个格式化金额的函数,并在.html页面中正确导入和使用该函数。此外,还提到了函数的导出方式以及.sjs文件和JavaScript文件的区别。
摘要由CSDN通过智能技术生成

mpaas小程序在js文件中定义的函数在页面中调用会发生报错,要使用sjs文件来定义函数

SJS(safe/subset javascript)是小程序一套自定义脚本语言,可以在 AXML 中使用其构建页面结构。

SJS 是 JavaScript 语言的子集,与 JavaScript 是不同的语言,故二者语法并不一致,请勿将其等同于 JavaScript。

比如要定义一个格式化金额的函数

在.sjs文件中

/**
 * 金额格式化
 * @param amount 金额String||Number
 * @param precision 小数位数Number(0-20)
 * @param unit 是否带单位Boolean
 * @returns {string}
 */
const amountFormat = (amount, precision, unit) => {
  if (amount === '') amount = '0'
  precision = precision > 0 && precision <= 20 ? precision : 2
  amount =
    parseFloat((amount + '').replace(/[^\d.-]/g, '')).toFixed(precision) + ''
  const l = amount.split('.')[0].split('').reverse()
  const r = amount.split('.')[1]
  let t = ''
  for (let i = 0; i < l.length; i++) {
    t += l[i] + ((i + 1) % 3 === 0 && i + 1 !== l.length ? ',' : '')
  }
  if (unit) {
    return t.split('').reverse().join('') + '.' + r
  } else {
    return t.split('').reverse().join('') + '.' + r
  }
}

export default {
  amountFormat
}

.html中

<import-sjs name="filters" from=".sjs文件的路径"/>
<view>{{ filters.amountFormat(100) }}</view>

另外可以看出我这里导出函数的方式是统一导出的,另外的分别导出每个函数的语法也是可以的,改一下name就行,name属性就相当于import后那个{}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值