微信小程序:新功能WXS(2017.08.30新增)

2017.08.30开发工具更新

注意(来自官方文档)

  1. wxs 不依赖于运行时的基础库版本,可以在所有版本的小程序中运行。
  2. wxs 与 javascript 是不同的语言,有自己的语法,并不和 javascript 一致。
  3. wxs 的运行环境和其他 javascript 代码是隔离的,wxs 中不能调用其他 javascript 文件中定义的函数,也不能调用小程序提供的API。
  4. wxs 函数不能作为组件的事件回调。
  5. 由于运行环境的差异,在 iOS 设备上小程序内的 wxs 会比 javascript 代码快 2 ~ 20 倍。在 android 设备上二者运行效率无差异。
举个例子,在wxs出来之前,如果我们要连接一个数组的内容并显示在wxml中,我们需要通过循环连接数组的每一项:

.wxml

<view>
    <block wx:for="{{names}}" wx:key="item">
        {{item}}
    </block>
</view>

.js

Page({
    data: {
        names:[
            'Tom',
            'Peter',
            'Gray',
            'Lisa'
        ]
    },
})

或者先在js中连接好,放在data中,再显示在wxml中:
.wxml

<view>
    {{content}}
</view>

.js

Page({
    data: {
        content:"",
        names:[
            'Tom',
            'Peter',
            'Gray',
            'Lisa'
        ]
    },
    onLoad(options){
        let content = this.data.names.join(" ")
        this.setData({
            content
        })
    }
})
有了wxs后,我们可以直接在wxml完成:

.wxml

<wxs module="util">
    var joinArray = function (array) {
        return array.join(' ')
    }

    module.exports = {
        joinArray: joinArray
    }
</wxs>
<view>
    {{util.joinArray(names)}}
</view>

或者将工具函数保存为单独的文件,通过引入来使用:
/src/wxs/common.wxs

var joinArray = function (array) {
    return array.join(' ')
}

module.exports = {
    joinArray: joinArray
}

/pages/index/index.wxml

<wxs src="../../src/wxs/common.wxs" module="util" />
<view>
    {{util.joinArray(names)}}
</view>

引入的时候,wxs标签src填写相对路径(绝对路径无效),module指定名字。

我们也可以将页面中的一些常量放在wxs中:
var MAX_COUNT = 19
module.exports = {
    MAX_COUNT: MAX_COUNT
}

总结:

  • WXS增强了wxml的功能,相当于页面中的脚本语言,我们可以将比如检查手机格式的函数放在wxs中来使用(根据是否正确来改变相应的样式),而不用跑到在js中去检查。

需要注意的地方:

  • wxs目前似乎并不支持ES6(至少let不能使用)
  • wxs文件不能被js文件引用。wxs文件能引用wxs文件。

参考:
微信小程序WXS官方文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,719评论 19 139
  • 前言 微信之父张小龙在年初的那次演讲中曾表示:“我自己是很多年的程序员,我觉得我们应该为开发的团队做一些事情”。几...
    4638d5195a5f阅读 5,218评论 0 2
  • 「你拍我画」风景类|放松心情的时刻http://www.jianshu.com/p/50639b1dfb41/风景...
    年少时光不该用来挥霍阅读 1,293评论 0 0
  • 他最近喜欢看月亮。散发着珍珠般光泽的月亮,在黑色云朵的缝隙里穿梭,就像一个女人被人撕破天鹅绒晚礼服后暴...
    梨涡小篆本尊阅读 3,207评论 0 1