微信小程序:新功能WXS解讀(2017.08.30新增) - 新聞資訊 - 雲南小程序開發|雲南軟件開發|雲南網站建設-昆明融晨信息技術有限公司

159-8711-8523

雲南網建設/小程序開發/軟件開發

知識

不(bù)管是(shì)網站,軟件還是(shì)小程序,都要(yào / yāo)直接或間接能爲(wéi / wèi)您産生價值,我們在(zài)追求其視覺表現的(de)同時(shí),更側重于(yú)功能的(de)便捷,營銷的(de)便利,運營的(de)高效,讓網站成爲(wéi / wèi)營銷工具,讓軟件能切實提升企業内部管理水平和(hé / huò)效率。優秀的(de)程序爲(wéi / wèi)後期升級提供便捷的(de)支持!

您當前位置>首頁 » 新聞資訊 » 小程序相關 >

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

發表時(shí)間:2021-4-30

發布人(rén):融晨科技

浏覽次數:109


注意(來(lái)自官方文檔)

  1. wxs 不(bù)依賴于(yú)運行時(shí)的(de)基礎庫版本,可以(yǐ)在(zài)所有版本的(de)小程序中運行。
  2. wxs 與 javascript 是(shì)不(bù)同的(de)語言,有自己的(de)語法,并不(bù)和(hé / huò) javascript 一緻。
  3. wxs 的(de)運行環境和(hé / huò)其他(tā) javascript 代碼是(shì)隔離的(de),wxs 中不(bù)能調用其他(tā) javascript 文件中定義的(de)函數,也(yě)不(bù)能調用小程序提供的(de)API。
  4. wxs 函數不(bù)能作爲(wéi / wèi)組件的(de)事件回調。
  5. 由于(yú)運行環境的(de)差異,在(zài) iOS 設備上(shàng)小程序内的(de) wxs 會比 javascript 代碼快 2 ~ 20 倍。在(zài) android 設備上(shàng)二者運行效率無差異。
舉個(gè)例子(zǐ),在(zài)wxs出(chū)來(lái)之(zhī)前,如果我們要(yào / yāo)連接一個(gè)數組的(de)内容并顯示在(zài)wxml中,我們需要(yào / yāo)通過循環連接數組的(de)每一項:

.wxml

  1. <view>
  2. <block wx:for="{{names}}" wx:key="item">
  3. {{item}}
  4. </block>
  5. </view>

.js

  1. Page({
  2. data: {
  3. names:[
  4. 'Tom',
  5. 'Peter',
  6. 'Gray',
  7. 'Lisa'
  8. ]
  9. },
  10. })

或者先在(zài)js中連接好,放在(zài)data中,再顯示在(zài)wxml中: 
.wxml

  1. <view>
  2. {{content}}
  3. </view>

.js

  1. Page({
  2. data: {
  3. content:"",
  4. names:[
  5. 'Tom',
  6. 'Peter',
  7. 'Gray',
  8. 'Lisa'
  9. ]
  10. },
  11. onLoad(options){
  12. let content = this.data.names.join(" ")
  13. this.setData({
  14. content
  15. })
  16. }
  17. })

有了(le/liǎo)wxs後,我們可以(yǐ)直接在(zài)wxml完成:

.wxml

  1. <wxs module="util">
  2. var joinArray = function (array) {
  3. return array.join(' ')
  4. }
  5. module.exports = {
  6. joinArray: joinArray
  7. }
  8. </wxs>
  9. <view>
  10. {{util.joinArray(names)}}
  11. </view>

或者将工具函數保存爲(wéi / wèi)單獨的(de)文件,通過引入來(lái)使用: 
/src/wxs/common.wxs

  1. var joinArray = function (array) {
  2. return array.join(' ')
  3. }
  4. module.exports = {
  5. joinArray: joinArray
  6. }

/pages/index/index.wxml

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

引入的(de)時(shí)候,wxs标簽src填寫相對路徑(絕對路徑無效),module指定名字。

我們也(yě)可以(yǐ)将頁面中的(de)一些常量放在(zài)wxs中:

  1. var MAX_COUNT = 19
  2. module.exports = {
  3. MAX_COUNT: MAX_COUNT
  4. }

總結:

  • WXS增強了(le/liǎo)wxml的(de)功能,相當于(yú)頁面中的(de)腳本語言,我們可以(yǐ)将比如檢查手機格式的(de)函數放在(zài)wxs中來(lái)使用(根據是(shì)否正确來(lái)改變相應的(de)樣式),而(ér)不(bù)用跑到(dào)在(zài)js中去檢查。

需要(yào / yāo)注意的(de)地(dì / de)方:

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

參考:
微信小程序WXS官方文檔



相關案例查看更多