700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > mPaas小程序(支付宝 钉钉...)页面中(axml中)使用函数(使用.sjs文件)

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

时间:2020-12-11 23:22:34

相关推荐

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

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 : 2amount =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后那个{}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。