39、WXS脚本(小程序独有的一套脚本语言)
(1)作用:结合WXML,可以构建出页面结构
(2)应用:在小程序中充当过滤器。(wxml无法调用在页面的.js中定义的函数,但是wxml中可以调用wxs中定义的函数)
(3)wxs与js的关系(wxs的语法类似于js)
1)wxs有自己的数据类型
Number、string、boolean、object、function、array、、date日期类型、regexp正则
2)wxs不支持类似于ES6及以上的语法形式
不支持:let、const、解构赋值、展开运算符、箭头函数、对象属性简写
支持:var定义变量、普通函数类似于ES5的语法
3)wxs遵循CommonJs规范
Module对象、require()函数、module.exports对象
(4)内嵌wxs脚本
Wxs代码可以写在wxml文件的wxs标签中,类似于js代码可以写在html文件的script标签中一样
1)wxs标签注意事项
①必须提供module属性,用来指定当前wxs的模块名称
②语法
已知:
data:image/s3,"s3://crabby-images/75b52/75b523cd3d93874e3cc5f19fb33da29670690d47" alt=""
(5)外联wxs脚本
Wxs代码还可以编写在以.wxs后缀结尾的文件内,就像js代码可以编写在以.js文件结尾的文件中一样
1)在wxml中引入外联的wxs脚本时的注意事项
①在wxml中引入外联的wxs脚本时,必须为<wxs>标签添加module(用来指定模块的名称)和src属性(用来指定要引入的脚本路径)(src必须是相对路径)
②语法:
已知:
data:image/s3,"s3://crabby-images/78c76/78c76f1c5a44b732fc9d5d34f20c6d8542eb62ed" alt=""
新建.wxs结尾的文件
data:image/s3,"s3://crabby-images/58fbc/58fbc4a9e375a970b87b506dcb7565fa4a1cbaca" alt=""
新建方法
data:image/s3,"s3://crabby-images/7817a/7817ab8bb160ca03e74da20c8b2e288dc4cb99a8" alt=""
导出方法
data:image/s3,"s3://crabby-images/b7feb/b7feb4c3638f2b94e8321535df3c4d27867a22a8" alt=""
导入
data:image/s3,"s3://crabby-images/181da/181da4d59206c5dfd80abe484410fd64909b5e3b" alt=""
使用
data:image/s3,"s3://crabby-images/fd74d/fd74d71ba3dbae0027d7b2fb3d727408b8afc71b" alt=""
(6)wxs的特点(wxs和js是完全不同的两种语言)
1)与js不同
为了降低Wxs的学习成本,wxs语言在设计时借鉴了大量的js语法,但是,本质上,wxs和js是完全不同的两种语言
2)不能作为组件的事件回调
Wxs典型的应用场景就是"过滤器",经常配合Mustache语法(插值表达式)进行使用,但是,在wxs中定义的函数不能作为组件的事件回调函数(不能用bind:tap绑定其中的方法)
3)隔离性(wxs的运行环境和其他js代码是隔离的)
①wxs不能调用js中定义的函数
②wxs不能调用小程序提供的API
4)性能好
①在ios设备上,小程序内的WXS会比js代码快2~20倍
②在Android设备上,二者的运行效率无差异
40、自定义组件
(1)组件的创建(为保证目录结构的清晰,建议把不同的组件,存放在单独的目录中)
1)在根目录新建components文件夹
data:image/s3,"s3://crabby-images/c3be1/c3be1a0aa72f78dad063b8b5e0f4cd4228534561" alt=""
2)在components文件夹下,右键,点击"新建Component",新建test文件
data:image/s3,"s3://crabby-images/c4550/c4550fe4165de3055ce1a2de0d8dcf712dafa480" alt=""
data:image/s3,"s3://crabby-images/42f58/42f58b44e83d8d326fdc225179fc7c52a4d2aef5" alt=""
(2)引用组件
1)分类
①局部引用(组件只能在当前被引用的页面内使用)(在页面的json文件中配置组件方式)
data:image/s3,"s3://crabby-images/d8009/d80092de694886b1e6c4ab72e4ed6ba12bb81921" alt=""
data:image/s3,"s3://crabby-images/63901/63901ae9d1ceba935dd7c1c8e1cb9038730ddf23" alt=""
在其他页面无效
data:image/s3,"s3://crabby-images/c9f3d/c9f3d0152e67da1f6c482a11a20ad2958f8220ec" alt=""
②全局引用(组件可以在小程序的每个页面中使用)(在app.json中配置引用组件的方式)
data:image/s3,"s3://crabby-images/a0096/a0096630507c4b4aa27bed95515335769ddda8ee" alt=""
data:image/s3,"s3://crabby-images/2149b/2149b6a4e097ba566cb26aa1c192fc4c1ed277f0" alt=""
data:image/s3,"s3://crabby-images/d84e5/d84e59fe58e2bf4e7e20b3b79edcb8454a3965ed" alt=""
3)全局引用与局部引用的区别(从使用频率和范围来看)
①如果某组件在多个页面中经常用到,建议进行"全局引用"
②如果某个组件只在特定的页面中被用到,建议进行"局部引用"
(3)组件与页面的区别
1)组件的.json文件中需要声明"component":true属性
data:image/s3,"s3://crabby-images/7eea0/7eea05a53287d918168f46615564e7489d930c46" alt=""
2)组件的.js文件中调用的是Component()函数
data:image/s3,"s3://crabby-images/399b8/399b87612f8b2bdf1be89c5daebadfc51e91c6ef" alt=""
3)组件的事件处理函数需要定义到methods节点中
data:image/s3,"s3://crabby-images/9bd19/9bd19ecaedd225e18b2a60b7bc6d4ead1a99928d" alt=""
(4)组件样式隔离
1)默认情况下,自定义组件的样式支队当前组件生效,不会影响组件之间的UI结构,比如:组件与组件之间、组件与小程序之间、小程序与组件们之间
2)好处:
①防止外界样式影响组件内部的样式
②防止组件的样式破坏外界的样式
3)注意:
①app.wxss中的全局样式对组件无效(具体来讲,是对组件内的标签无效)
data:image/s3,"s3://crabby-images/d33db/d33dbf69332893831d9154018b282338aaa5bdd2" alt=""
data:image/s3,"s3://crabby-images/15fce/15fce0e8c28dcad40a1f3081f7592b6e4bb8cc1c" alt=""
data:image/s3,"s3://crabby-images/36d42/36d422181f9c2eeb0682507c4b652c6eb1377f92" alt=""
②只有class选择器会有样式隔离的效果,id选择器、属性选择器、标签选择器不受样式隔离的影响
data:image/s3,"s3://crabby-images/d6769/d676961a9e812998e819bbe7738e27922d0433f4" alt=""
(5)修改组件样式的隔离选项
默认情况下,自定义组件 的样式隔离性能防止组件内外样式互相干扰的问题,但是有时需要外界能够控制组件内部的样式,可以通过styleIsolation实现
1)styleIsolation的可选值
①isolated(表示启用样式隔离,在自定义组件内外,使用class指定的样式不会相互影响):默认值为是
data:image/s3,"s3://crabby-images/a7fc3/a7fc380b0ffd3f860e7d39963e2e42d8adf07a7d" alt=""
②apply-shared(表示页面wxss样式将影响到自定义组件,但自定义组件不会影响到页面):默认值为否
data:image/s3,"s3://crabby-images/aa020/aa020200f658fcb2e310a6b3ccd57daa7751f453" alt=""
③shared(表示页面wxss样式影响到自定义组件,定义组件也影响到页面):默认值为否
data:image/s3,"s3://crabby-images/95020/95020ed5cd68d04825465e83b9984ab5d428372e" alt=""
data:image/s3,"s3://crabby-images/8d276/8d276d04156de5575c2d48843c11c2d9528d80db" alt=""
2)语法:
①在组件的.json中配置
data:image/s3,"s3://crabby-images/1f74d/1f74d723f03ae0e882cb994a60b54a4a69b29dca" alt=""
②在组件的js文件中配置
data:image/s3,"s3://crabby-images/aba4b/aba4b08c37a9e2deecf2269199a9d2d718cef068" alt=""