Rumah > applet WeChat > Pembangunan program mini > Penjelasan terperinci tentang lapisan paparan applet WeChat

Penjelasan terperinci tentang lapisan paparan applet WeChat

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Lepaskan: 2022-05-23 12:02:33
ke hadapan
5018 orang telah melayarinya

Artikel ini membawakan anda pengetahuan yang berkaitan tentang Program Mini WeChat Ia terutamanya memperkenalkan isu berkaitan tentang lapisan paparan bertanggungjawab untuk memaparkan data lapisan logik pada halaman masa Hantar peristiwa lapisan paparan ke lapisan logik. Saya harap ia akan membantu semua orang.

Penjelasan terperinci tentang lapisan paparan applet WeChat

[Cadangan pembelajaran berkaitan: Tutorial pembelajaran program mini]

Lapisan paparan rangka kerja program mini terdiri daripada WXML ( Bahasa Penanda WeiXin, bahasa penanda WeChat) dan WXSS (Helaian Gaya WeiXin, helaian gaya WeChat) ditulis dan dipaparkan oleh komponen. Lapisan paparan bertanggungjawab untuk memaparkan data daripada lapisan logik pada halaman dan menghantar peristiwa dari lapisan paparan ke lapisan logik. WXML digunakan untuk menerangkan struktur halaman, WXSS digunakan untuk menerangkan gaya halaman, dan komponen ialah komponen asas paparan. Hubungan antara ketiga-tiga ini boleh dibandingkan dengan hubungan antara HTML, CSS dan pelbagai tag dalam HTML. Sebagai tambahan kepada ketiga-tiga ini, terdapat juga bahasa skrip untuk program kecil-WXS (WeiXin Script). WXS dan WXML digabungkan untuk membina struktur halaman.

1. WXML

1. Pengikatan data

(1) Pengikatan mudah

Prinsip asas pengikatan data :
1) Tentukan data halaman dalam data: Dalam fail .js yang sepadan dengan halaman, hanya tentukan data ke dalam objek data.

Page({
  data:{
    //字符串类型的数据
    info: 'init data ' ,
    //数组类型的数据
    msgList: [{msg: 'hello'},{msg: "world '}]
  }
})
Salin selepas log masuk

2) Gunakan data dalam WXML: Ikat data dalam data ke halaman untuk pemaparan dan gunakan sintaks Misai (kurung kurung berganda) untuk membalut pembolehubah. Format sintaks ialah:

<view>{{要绑定的数据名称}}</view>
Salin selepas log masuk

Senario aplikasi utama sintaks Misai adalah seperti berikut:
①Kandungan. Paparkan kandungan data terus pada halaman.
②Sifat komponen. Gunakan pembolehubah hujung belakang untuk menetapkan sifat beberapa komponen bahagian hadapan Harap maklum bahawa pembolehubah yang disertakan dengan pendakap kerinting berganda perlu berada dalam petikan berganda sifat.
③Kawal atribut. Gunakan pembolehubah hujung belakang untuk mengawal kesan paparan komponen hujung hadapan Ambil perhatian bahawa pembolehubah yang disertakan dengan pendakap kerinting berganda perlu berada dalam petikan berganda atribut.
④Kata kunci. Terutamanya digunakan untuk pertimbangan logik.

(2) Operasi

①Kendalian Ternary. Operasi ternary boleh dilakukan dalam pendakap kerinting berganda.
Dalam .js:

Page({
  data: {
    randomNum:Math.random()*10
  }
})
Salin selepas log masuk

Dalam .wxml:

<view>{{randomNum>=5?'数字大于等于5':'数字小于5'}}</view>
Salin selepas log masuk

② Operasi aritmetik. Dalam kurungan kerinting berganda, operasi aritmetik asas boleh dilakukan dan hasil operasi akan dipaparkan terus.
③Penghakiman logik. Dalam pendakap berganda, operasi logik boleh dilakukan, mengembalikan benar atau palsu jenis boolean, yang boleh digunakan untuk mengawal atribut tertentu.
④Operasi rentetan. Dalam pendakap berganda, operasi penggabungan rentetan boleh dilakukan.
⑤Kendalian laluan data. Untuk data jenis objek tatasusunan dan JSON, nilai boleh diperoleh dengan mengindeks dalam kurungan kerinting berganda.

(3) Gabungan

①Array
②Objek

2 rendering senarai

(1) wx:for

Menggunakan. wx:for, anda boleh gelung untuk memaparkan struktur komponen berulang berdasarkan tatasusunan yang ditentukan Contoh sintaks adalah seperti berikut:
Dalam .js:

Page({
  data: {
    array:['a','b','c']
  }
})
Salin selepas log masuk

Dalam .wxml:

<view>
 索引是:{{index}},当前项是:{{item}}
</view>
Salin selepas log masuk

Kesannya adalah seperti yang ditunjukkan:
Penjelasan terperinci tentang lapisan paparan applet WeChat
Secara lalai, indeks item gelung semasa diwakili oleh indeks item gelung semasa;

(2) Tentukan indeks dan nama pembolehubah item semasa secara manual*

  • Gunakan wx:for-index untuk menentukan nama pembolehubah indeks item gelung semasa
  • Gunakan wx:for-item untuk menentukan nama pembolehubah item semasa
    Dalam wxml:
<view>
 索引是:{{idx}},当前项是:{{itemName}}
</view>
Salin selepas log masuk

Kesannya adalah seperti berikut:
Penjelasan terperinci tentang lapisan paparan applet WeChat

(3 ) wx:key

adalah serupa dengan :key dalam pemaparan senarai Vue Apabila applet melaksanakan pemaparan senarai, ia juga disyorkan untuk menentukan nilai kunci unik untuk senarai yang diberikan. item untuk meningkatkan kecekapan pemaparan. Contoh kod Seperti berikut:

Dalam .js:

Page({
  data: {
    userList:[
      {id:1,name:'冠军'},
      {id:2,name:'亚军'},
      {id:3,name:'季军'}
    ]
  }
})
Salin selepas log masuk
Dalam wxml:

<view>{{item.name}}</view>
Salin selepas log masuk
Kesannya adalah seperti yang ditunjukkan:

<.>
Nilai wx:key disediakan dalam dua bentuk berikut: Penjelasan terperinci tentang lapisan paparan applet WeChat 1) Rentetan. Mewakili atribut item dalam tatasusunan gelung wx:for Nilai atribut perlu rentetan atau nombor unik dalam senarai dan tidak boleh diubah secara dinamik.
2) Kata kunci terpelihara *ini. Mewakili item itu sendiri dalam gelung wx:for Perwakilan ini memerlukan item itu sendiri menjadi rentetan atau nombor yang unik.

3. Paparan bersyarat

(1) wx:if

Dalam program mini, gunakan wx:if="{

{condition}}" untuk menilai Sama ada anda perlu membuat blok kod, anda juga boleh menggunakan wx:elif dan wx:else untuk menambah pertimbangan lain. Contohnya adalah seperti berikut:

Dalam .js:

Dalam .wxml:
Page({
  data: {
    type:1
  }
})
Salin selepas log masuk
<view>男</view>
<view>女</view>
<view>保密</view>
Salin selepas log masuk

(2)结合 <block></block> 使用 wx:if

如果要一次性控制多个组件的展示与隐藏,可以使用一个 <block></block> 标签将多个组件包装起来,并在<block></block> 标签上使用 wx:if 控制属性,示例如下:

<block>
 <view>view1</view>
 <view>view2</view>
</block>
Salin selepas log masuk

注意: <block></block> 并不是一个组件,它只是一个包裹性质的容器,不会在页面中做任何渲染。

(3)hidden

在小程序中,直接使用 hidden="{{ condition }}" 也能控制元素的显示与隐藏:

<view>true隐藏,false显示</view>
Salin selepas log masuk

(4)wx:if 对比 hidden

1)运行方式不同:
wx:if 以动态创建和移除元素的方式,控制元素的展示与隐藏。
hidden 以切换样式的方式(display: none/block;),控制元素的显示与隐藏。
2)使用建议:
频繁切换时,建议使用 hidden。
控制条件复杂时,建议使用 wx:if 搭配 wx:elif、wx:else 进行展示与隐藏的切换。

4.事件

事件是视图层到逻辑层的通信方式,它可以将用户的行为反馈到逻辑层讲行处理。事件一般绑定在组件上,当设定监听的事件被触发时,视图层会将携带了id、dataset、touches等信息的事件对象发送到逻辑层中,此时框架就会执行逻辑层中
对应的事件处理函数,来响应用户的操作。

事件分为冒泡事件和非冒泡事件。

  • 冒泡事件:当一个组件上的事件被触发后,该事件会向父节点传递。
  • 非冒泡事件:当一个组件上的事件被触发后,该事件不会向父节点传递。

(1)事件的使用方式

.wxml中:

<button>按钮</button>
Salin selepas log masuk

.js中定义事件处理函数:

Page({
  // 定义按钮的事件处理函数
  btnTapHandler(event){
    console.log(event)
  }
})
Salin selepas log masuk

效果如图:
Penjelasan terperinci tentang lapisan paparan applet WeChat
调试器的Console面板输出信息大致为:
Penjelasan terperinci tentang lapisan paparan applet WeChat

(2)事件的分类

Penjelasan terperinci tentang lapisan paparan applet WeChat

(3)事件的绑定和冒泡

(4)事件的捕获阶段

(5)事件对象

当组件触发事件时。逻辑层绑定该事件的处理函数会收到一个事件对象。
Penjelasan terperinci tentang lapisan paparan applet WeChat

(6)在事件处理函数中为 data 中的数据赋值

通过调用 this.setData(dataObject) 方法,可以给页面 data 中的数据重新赋值。示例如下:
.wxml中:

<button>+1</button>
Salin selepas log masuk

.js中定义事件处理函数:

Page({
  data: {
    count:0
  },
  
  //+1 按钮的事件处理函数
  countChange(){
    this.setData({
      count:this.data.count +1
    })
  }
})
Salin selepas log masuk

效果如图:
Penjelasan terperinci tentang lapisan paparan applet WeChat
Penjelasan terperinci tentang lapisan paparan applet WeChat

(7)事件传参

小程序中的事件传参比较特殊,不能在绑定事件的同时为事件处理函数传递参数。可以为组件提供 data-* 自定义属性传参,其中 * 代表的是参数的名字,示例代码如下:

.wxml中:( info 会被解析为参数的名字,数值 2 会被解析为参数的值。)

<button>+2</button>
Salin selepas log masuk

.js中:(在事件处理函数中,通过 event.target.dataset.参数名 即可获取到具体参数的值)

Page({
  data: {
    count:0
  },
  
  //+2 
  binTap2(event){
    this.setData({
      count:this.data.count + event.target.dataset.info
    })
  }
})
Salin selepas log masuk

效果如图:
Penjelasan terperinci tentang lapisan paparan applet WeChat
Penjelasan terperinci tentang lapisan paparan applet WeChat

(8)bindinput 的语法格式

在小程序中,通过 input 事件来响应文本框的输入事件。
.wxml中:

<input>
Salin selepas log masuk

.js 中定义事件处理函数:

Page({
  //input输入框的事件处理函数
  inputHandler(event){
    console.log(event.detail.value)
  }
})
Salin selepas log masuk

效果如图:
Penjelasan terperinci tentang lapisan paparan applet WeChat
Penjelasan terperinci tentang lapisan paparan applet WeChat

(9)实现文本框和 data 之间的数据同步

实现步骤:①定义数据;②渲染结构;③美化样式;④绑定 input 事件处理函数。

5.模板

6.引用

WXML提供两种文件引用方式:import 和 include
1)import 可以在该文件中使用目标文件定义的模板。import 有作用域的概念,即只会导入目标文件中定义的模板,而不会导入目标文件导入的模板。
2)include 可以将目标文件除了<template></template><wxs></wxs>外的整个代码引入,相当于复制到 include 位置。

二、WXSS

WXSS (WeiXin Style Sheets)是一套样式语言,用于美化 WXML 的组件样式,类似于网页开发中的 CSS。WXSS 具有 CSS 大部分特性,同时,WXSS 还对 CSS 进行了扩充以及修改,以适应微信小程序的开发。
与 CSS 相比,WXSS 扩展的特性有:

  • rpx 尺寸单位
  • @import 样式导入

1.尺寸单位

rpx(responsive pixel)是微信小程序独有的,用来解决屏适配的尺寸单位。
rpx 的实现原理非常简单:鉴于不同设备屏幕的大小不同,为了实现屏幕的自动适配,rpx 把所有设备的屏幕,在宽度上等分为 750 份(即:当前屏幕的总宽度为 750rpx)。

  • 在较小的设备上,1rpx 所代表的宽度较小
  • 在较大的设备上,1rpx 所代表的宽度较大

小程序在不同设备上运行的时候,会自动把 rpx 的样式单位换算成对应的像素单位来渲染,从而实现屏幕适配。

在 iPhone6 上,屏幕宽度为375px,共有 750 个物理像素,等分为 750rpx。则:
750rpx = 375px = 750 物理像素
1rpx = 0.5px = 1物理像素
官方建议:开发微信小程序时,设计师可以用 iPhone6 作为视觉稿的标准。
Penjelasan terperinci tentang lapisan paparan applet WeChat

2.样式导入

使用 WXSS 提供的 @import 语法,可以导入外联的样式表。
@import 后跟需要导入的外联样式表的相对路径,用 ; 表示语句结束。

3.内联样式

内联样式是框架组件上支持使用 style、class 属性来控制组件的样式。
1)style:用于接收动态样式,在运行时会进行解析。
2)class:用于指定样式规则。其值是样式规则中类选择器名(样式类名)的集合。一般将静态样式写到对应样式类名的定义中。多个样式类名之间用空格分隔。

4.选择器

和CSS一样,WXSS也需要使用选择器来决定样式的作用对象。

5.全局样式与局部样式

1)全局样式:定义在 app.wxss 中的样式为全局样式,作用于每一个页面。
2)局部样式:在页面的 .wxss 文件中定义的样式为局部样式,只作用于当前页面。

注意:
当局部样式和全局样式冲突时,根据就近原则,局部样式会覆盖全局样式。
当局部样式的权重大于或等于全局样式的权重时,才会覆盖全局的样式。

三、WXS

1.概念

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

2.应用场景

wxml 中无法调用在页面的 .js 中定义的函数,但是,wxml 中可以调用 wxs 中定义的函数。因此,小程序中 wxs 的典型应用场景就是“过滤器”。

3.wxs 和 JavaScript 的关系

虽然 wxs 的语法类似于 JavaScript,但是 wxs 和 JavaScript 是完全不同的两种语言:
(1)wxs 有自己的数据类型:

  • number 数值类型
  • string 字符串类型
  • boolean 布尔类型
  • object 对象类型
  • function函数类型
  • array 数组类型
  • date 日期类型
  • regexp 正则

(2)wxs 不支持类似于 ES6 及以上的语法形式

  • 不支持:let、const、解构赋值、展开运算符、箭头函数、对象属性简写、etc…
  • 支持:var 定义变量、普通 function函数等类似于 ES5 的语法

(3)wxs 遵循 CommonJS 规范

  • module 对象
  • require() 函数
  • module.exports 对象

4.内嵌 wxs 脚本

wxs 代码可以编写在 wxml 文件中的 <wxs></wxs> 标签内,就像 Javascript 代码可以编写在 html 文件中的 <script></script> 标签内一样。
wxml 文件中的每个 <wxs></wxs> 标签,必须提供 module 属性,用来指定当前 wxs 的模块名称,方便在 wxml 中访问模块中的成员。
.wxml中:

<view>{{m1.toUpper(username)}}</view>

<wxs>
  //将文本转为大写形式zs -> ZS
  module.exports.toUpper = function(str) {
    return str.toUpperCase()
  }
</wxs>
Salin selepas log masuk

5.定义外联的 wxs 脚本

wxs 代码还可以编写在以 .wxs 为后缀名的文件内,就像 javascript 代码可以编写在以 .js 为后缀名的文件中一样。示例代码如下:

//tools.wxs文件
function toLower(str) {
  return str.toLowerCase()
}

module.exports = {
  toLower: toLower
}
Salin selepas log masuk

6.使用外联的 wxs 脚本

在 wxml 中引入外联的 wxs 脚本时,必须为 标签添加 module 和 src 属性,其中:

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

示例代码如下:

<!--调用m2模块中的方法-->
<viewr>{{m2.toLower(country)}}

<!--引用外联的tools.wxs脚本,并命名为 m2-->
<wxs></wxs></viewr>
Salin selepas log masuk

7.WXS 的特点

(1)与 JavaScript 不同
为了降低 wxs(WeiXin Script)的学习成本, wxs 语言在设计时借大量鉴了 JavaScript 的语法。但是本质上,wxs 和 JavaScript 是完全不同的两种语言!
(2)不能作为组件的事件回调
wxs 典型的应用场景就是“过滤器”,经常配合 Mustache 语法进行使用。但是,在 wxs 中定义的函数不能作为组件的事件回调函数。
(3)隔离性
隔离性指的是 wxs 的运行环境和其他 JavaScript 代码是隔离的。体现在如下两方面:
①wxs 不能调用 js 中定义的函数
②wxs 不能调用小程序提供的 API
(4)性能好
①在 iOS 设备上,小程序内的 WXS 会比 JavaScript 代码快 2 ~ 20 倍
②在 android 设备上,二者的运行效率无差异

【相关学习推荐:小程序学习教程

Atas ialah kandungan terperinci Penjelasan terperinci tentang lapisan paparan applet WeChat. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:csdn.net
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan