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

news/2024/11/8 18:42:57/

请添加图片描述

  • 💌 所属专栏:【微信小程序开发教程】

  • 😀 作  者:我是夜阑的狗🐶

  • 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询!

  • 💖 欢迎大家:这里是CSDN,我总结知识的地方,喜欢的话请三连,有问题请私信 😘 😘 😘

文章目录

  • 前言
  • 一、WXS 脚本
      • 1、什么是 wxs
      • 2、wxs 的应用场景
      • 3、. wxs 和 JavaScript 的关系
  • 二、WXS 脚本 - 基础语法
      • 1、内嵌 wxs 脚本
      • 2、定义外联的 wxs 脚本
      • 3、使用外联的 wxs 脚本
  • 三、WXS 的特点
      • 1、与 JavaScript 不同
      • 2、不能作为组件的事件回调
      • 3、隔离性
      • 4、性能好
  • 总结


前言

  大家好,又见面了,我是夜阑的狗🐶,本文是专栏【微信小程序开发教程】专栏的第29篇文章;
  今天开始学习微信小程序的第15天💖💖💖,开启新的征程,记录最美好的时刻🎉,每天进步一点点。
  专栏地址:【微信小程序开发教程】, 此专栏是我是夜阑的狗微信小程序开发过程的总结,希望能够加深自己的印象,以及帮助到其他的小伙伴😉😉。
  如果文章有什么需要改进的地方还请大佬不吝赐教👏👏。


一、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 脚本的介绍使用,如果觉得有帮助,请给文章点个赞吧,让更多的人看到。🌹 🌹 🌹

在这里插入图片描述

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

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

更多专栏订阅:

  • 😀 【LeetCode题解(持续更新中)】
  • 🚝 【Java Web项目构建过程】
  • 💛 【微信小程序开发教程】
  • 【JavaScript随手笔记】
  • 🤩 【大数据学习笔记(华为云)】
  • 🦄 【程序错误解决方法(建议收藏)】
  • 🚀 【软件安装教程】



订阅更多,你们将会看到更多的优质内容!!


http://www.ppmy.cn/news/31156.html

相关文章

ALG和STUN

目录 ALG 应用层网关讲解 Client1使用FTP主动模式建立FTP Client1使用FTP被动模式建立FTP STUN讲解 ALG 应用层网关讲解 用来替换应用层信息 Client1使用FTP主动模式建立FTP 主动模式&#xff1a;服务器收到客户端发来的请求FTP的地址和端口 服务器使用20端口直接向客户端建…

LearnOpenGL-光照-1.颜色

本人刚学OpenGL不久且自学&#xff0c;文中定有代码、术语等错误&#xff0c;欢迎指正 我写的项目地址&#xff1a;https://github.com/liujianjie/LearnOpenGLProject 文章目录颜色OpenGL代码例子颜色 物体颜色简介 我们在现实生活中看到某一物体的颜色并不是这个物体真正拥有…

第十四届蓝桥杯第三期模拟赛 C/C++ B组 原题与详解

文章目录 一、填空题 1、1 找最小全字母十六进制数 1、1、1 题目描述 1、1、2 题解关键思路与解答 1、2 给列命名 1、2、1 题目描述 1、2、2 题解关键思路与解答 1、3 日期相等 1、3、1 题目描述 1、3、2 题解关键思路与解答 1、4 乘积方案数 1、4、1 题目描述 1、4、2 题解关…

Spring的@Conditional注解

前言Conditional是Spring4新提供的注解&#xff0c;它的作用是按照一定的条件进行判断&#xff0c;满足条件给容器注册bean。Conditional的源码定义&#xff1a;//此注解可以标注在类和方法上 Target({ElementType.TYPE, ElementType.METHOD}) Retention(RetentionPolicy.RUNTI…

【模板进阶】

目录 1. 非类型模板参数 2. 模板的特化 2.1 概念 2.2 函数模板特化 2.3 类模板特化 2.3.1 全特化 3 模板分离编译 3.1 什么是分离编译 3.2 模板的分离编译 4. 模板总结 有需要的老哥可以先看看模板的介绍&#xff1a;http://t.csdn.cn/2TkUYhttp://t.csdn.cn/2TkUY 1. …

嵌入式学习笔记——寄存器实现控制LED小灯

文章目录前言GPIO通用输出模式初始化LED小灯的GPIO原理图初始化代码初始化的效果功能函数封装直接分开宏定义两个使用条件运算符封装函数实现简单的功能前言 上一篇中&#xff0c;介绍了GPIO相关的所有寄存器&#xff0c;并在最后简单实现了一个LED灯的控制&#xff0c;由于那…

JDBC连接执行SQL

JDBC [Java DataBase Connectivity] JAVA数据库连接JDBC是SUN提供的一套API接口&#xff0c;使用JAVA连接数据库的一套标准接口。各个数据库提供上都提供了一套JDBC的实现类用于连接自家的DBMS。而提供的这一套实现类也称为连接该DBMS的驱动(Driver)1:要加载需要操作的DBMS厂商…

kube-ipam配置和使用说明

Kube-ipam基于etcd分布式存储实现kubernetes动态IP网络分配管理&#xff0c;确保集群中IP地址的唯一性。Kube-ipam支持给kubernetes集群中的Pod固定IP地址&#xff0c;同时支持resolv.conf的DNS配置。 1. 概述 一些场景往往对IP地址有依赖&#xff0c;需要使用固定IP地址的Po…