微信小程序视图层详解

本篇文章给大家带来了关于微信小程序的相关知识,其中主要介绍了关于视图层的相关问题,视图层负责将逻辑层的数据显示在页面上,同时将视图层的事件发送给逻辑层,下面一起来看一下,希望对大家有帮助。

微信小程序视图层详解

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

小程序框架的视图层由WXML(WeiXin Markup Language,微信标记语言)与WXSS(WeiXin Style Sheet,微信样式表)编写,由组件来进行展示。视图层负责将逻辑层的数据显示在页面上,同时将视图层的事件发送给逻辑层。WXML用来描述页面的结构,WXSS用于描述页面的样式,组件是视图的基本组成单元。这三者的关系可以类比为HTML,CSS与HTML里面各种标签的关系。除了这三者之外,还有一套用于小程序的脚本语言——WXS(WeiXin Script)。WXS和WXML结合起来,可以构建出页面结构。

一、WXML

1、数据绑定

(1)简单绑定

数据绑定的基本原则: 1)在 data 中定义页面的数据:在页面对应的 .js 文件中,把数据定义到 data 对象中即可。

Page({ data:{ //字符串类型的数据 info: 'init data ' , //数组类型的数据 msgList: [{msg: 'hello'},{msg: "world '}] } })登录后复制

{{要绑定的数据名称}}登录后复制

(2)运算

①三元运算。可以在双大括号内进行三元运算。 .js中:

Page({ data: { randomNum:Math.random()*10 } })登录后复制

{{randomNum>=5?'数字大于等于5':'数字小于5'}}登录后复制

(3)组合

①数组 ②对象

2.列表渲染

(1)wx:for

通过 wx:for 可以根据指定的数组,循环渲染重复的组件结构,语法示例如下: .js中:

Page({ data: { array:['a','b','c'] } })登录后复制

索引是:{{index}},当前项是:{{item}} 登录后复制

(2)手动指定索引和当前项的变量名*

  • 使用 wx:for-index 可以指定当前循环项的索引的变量名
  • 使用 wx:for-item 可以指定当前项的变量名 .wxml中:

索引是:{{idx}},当前项是:{{itemName}} 登录后复制

(3)wx:key

类似于 Vue 列表渲染中的 :key,小程序在实现列表渲染时,也建议为渲染出来的列表项指定唯一的 key 值,从而提高渲染的效率,示例代码如下: .js中:

Page({ data: { userList:[ {id:1,name:'冠军'}, {id:2,name:'亚军'}, {id:3,name:'季军'} ] } })登录后复制

{{item.name}}登录后复制

3.条件渲染

(1)wx:if

在小程序中,使用 wx:if="{{condition}}" 来判断是否需要渲染该代码块,也可以用 wx:elif 和 wx:else 来添加 else 判断。示例如下: .js中:

Page({ data: { type:1 } })登录后复制

男 女 保密登录后复制