【微信小程序】-- WXS 脚本(二十九)

简介: 【微信小程序】-- WXS 脚本(二十九)



一、WXS 脚本

  前面已经大致了解小程序中生命周期,分别是应用生命周期和页面生命周期,在实际开发过程中,一般初始化数据的操作都会放在 onLoad 或者 onLaunch 里。所以了解生命周期的执行顺序与作用对后续的开发很有帮助。接下来就来学习一下小程序中的 WXS 脚本。话不多说,让我们原文再续,书接上回吧。

1、什么是 wxs

  WXS(WeiXin Script)是小程序独有的一套脚本语言,结合 WXML,可以构建出页面的结构。

2、wxs 的应用场景

  wxml 中无法调用在页面的 .js 中定义的函数,但是,wxml 中可以调用 wxs 中定义的函数。因此,小程序中

wxs 的典型应用场景就是“过滤器”,这一点跟 Vue 有点类似。

3、. wxs 和 JavaScript 的关系

  虽然 wxs 的语法类似于 JavaScript,但是 wxs 和 JavaScript 是完全不同的两种语言:

wxs 作用
有自己的数据类型 number 数值类型、string 字符串类型、boolean 布尔类型、object 对象类型
function 函数类型、array 数组类型、 date 日期类型、 regexp 正则
不支持类似于 ES6 及以上的语法形式 不支持:let、const、解构赋值、展开运算符、箭头函数、对象属性简写、etc…
支持:var 定义变量、普通 function 函数等类似于 ES5 的语法
遵循 CommonJS 规范 module 对象、require() 函数、module.exports 对象

二、WXS 脚本 - 基础语法

1、内嵌 wxs 脚本

  wxs 代码可以编写在 wxml 文件中的 <wxs> 标签内,就像 Javascript 代码可以编写在 html 文件中的 <script> 标签内一样。

  wxml 文件中的每个 <wxs></wxs> 标签,必须提供 module 属性,用来指定当前 wxs 的模块名称,方便在 wxml 中访问模块中的成员,这里可以看下下面栗子,具体代码如下:

message.js

  首先在js端定义好变量。

Page({
  /**
   * 页面的初始数据
   */
  data: {
    count: 0,
    userName: "csh",
  },
})

message.wxml

  将文本转成大写。

<view>{{test1.toUpper(userName)}}</view>
<wxs module="test1">
  // 将文本转成大写
  module.exports.toUpper = function (str) {
    return str.toUpperCase();
  }
</wxs>

  不出意外的话,在页面会出 csh 的大写形式,看一下实际效果:

2、定义外联的 wxs 脚本

   wxs 代码还可以编写在以 .wxs 为后缀名的文件内,就像 javascript 代码可以编写在以 .js 为后缀名的文件中

一样。示例代码如下:

  创建 .wxs 文件

tool.wxs

function toLower(str){
  return str.toLowerCase();
}
module.exports = {
  toLower: toLower
}

  到这里就定义好模块里的函数。

3、使用外联的 wxs 脚本

  前面定义好了外联的 wxs 脚本,接下来就要去使用了。在 wxml 中引入外联的 wxs 脚本时,必须为 标签添加 module 和 src 属性,其中:

属性 说明
module 用来指定模块的名称
src 用来指定要引入的脚本的路径,且必须是相对路径

  通过下面的栗子来学习一下,具体代码如下:

message.js

  在js端定义好变量。

Page({
  /**
   * 页面的初始数据
   */
  data: {
    count: 0,
    userName: "csh",
    country: 'CHINA',
  },
})

message.wxml

  引用外联的tool.wxs 脚本,并命名为 test2,将文本转成小写。

<view>{{test2.toLower(country)}}</view>
<wxs src="../../utils/tool.wxs" module="test2"></wxs>

  可以来看一下实际效果:

三、WXS 的特点

1、与 JavaScript 不同

  为了降低 wxs(WeiXin Script)的学习成本, wxs 语言在设计时借大量鉴了 JavaScript 的语法。但是本质上,

wxs 和 JavaScript 是完全不同的两种语言!

2、不能作为组件的事件回调

  wxs 典型的应用场景就是“过滤器”,经常配合 Mustache 语法进行使用,例如:

<view>{{test1.toUpper(userName)}}</view>

  但是,在 wxs 中定义的函数不能作为组件的事件回调函数。例如,下面的用法是错误的:

<button bindtap="test2.toLower">按钮</button>

3、隔离性

  隔离性指的是 wxs 的运行环境和其他 JavaScript 代码是隔离的。体现在如下两方面:

  • wxs 不能调用 js 中定义的函数
  • wxs 不能调用小程序提供的 API

4、性能好

  在 iOS 设备上,小程序内的 WXS 会比 JavaScript 代码快 2 ~ 20 倍。

  在 android 设备上,二者的运行效率无差异


总结

  感谢观看,这里就是WXS 脚本的介绍使用,如果觉得有帮助,请给文章点个赞吧,让更多的人看到。🌹 🌹 🌹

  也欢迎你,关注我。👍 👍 👍

  原创不易,还希望各位大佬支持一下,你们的点赞、收藏和留言对我真的很重要!!!💕 💕 💕 最后,本文仍有许多不足之处,欢迎各位认真读完文章的小伙伴们随时私信交流、批评指正!下期再见。🎉


相关文章
|
9月前
|
Android开发
微信自动发朋友圈脚本,定时发朋友圈插件群发,多账户发朋友圈批量工具
整的微信朋友圈自动发布功能,包含环境检查、界面元素定位、图片识别、异常处理等模块
|
7月前
|
Shell Android开发 Python
微信多开脚本,微信双开器脚本插件,autojs开源代码分享
AutoJS脚本实现安卓端微信多开,通过无障碍服务 Python脚本提供跨平台解决方案,自动检测微信安装路径
|
8月前
|
JSON 机器人 API
微信机器人自动回复插件,vx自动回复机器人脚本助手,python框架分享
这个微信机器人系统包含三个主要模块:主程序基于itchat实现微信消息监听和自动回复功能
|
9月前
|
存储 调度
微信自动评论朋友圈,微信朋友圈自动发布工具,定时发朋友圈脚本
这个实现包含完整的微信朋友圈自动发布功能,支持定时发布、多图发布、任务持久化存储等功能
微信自动发朋友圈脚本,自动发朋友圈软件,批量发朋友圈工具autojs
使用时请确保已开启AutoJS的无障碍服务权限,建议在模拟器环境下测试通过后再部署到真机。实际运行前需根据自身需求修改CONFIG配置区块的参数。
|
8月前
|
调度 Android开发 数据安全/隐私保护
微信养号是什么意思?有脚本吗
Python实现微信养号自动化操作指南 作者前言
|
9月前
|
JSON 安全 定位技术
微信附近人提取v3脚本, 微信附近人id提取技术插件,采集附近人wxid数据工具
本内容介绍微信“附近的人”功能的技术原理与实现方法,基于LBS服务,涉及位置模拟、协议分析及数据解析。通过修改GPS坐标或使用Frida等工具hook位置函数
|
8月前
|
机器学习/深度学习 JSON 运维
微信抢红包脚本会封号吗?
微信抢红包脚本通常通过以下几种技术方式实现:
|
8月前
|
监控 数据库 数据安全/隐私保护
微信自动抢红包永久免费软件, 自动抢红包软件微信,脚本插件抢红包【python】
该实现包含三个核心模块:主监控程序、数据库记录模块和配置模块。主程序使用itchat监听微信消息
|
8月前
|
Android开发 数据安全/隐私保护 Python
微信抢红包脚本安卓插件,微信xposed抢红包模块, magisk微信抢红包模块
这个代码实现了一个完整的微信抢红包自动化工具,包含红包检测、自动点击、日志记录等功能