微信小程序 学习笔记 WXML 详解 wx:if wx:for

WXML 详解
WXML(WeiXin Markup Language)是框架设计的一套标签语言,结合基础组件事件系统,可以构建出页面的结构。

以下一些简单的例子来看看 WXML 具有什么能力:

一.数据绑定

WXML中的动态数据均来自对应js文件中的Page的data,在js中访问Page的data用this.data,改变data中的某个属性的值用setData()方法。

简单绑定数据

数据绑定使用的Mustache语法(双大括号)将变量包起来,可以作用于以下区域:

(1)作用于内容

//1.作用于内容不用写“”,直接{{变量}}
<view>{{title}}</view>
  data: {
      title:"标题"
  },

注意:作用于内容不用写“”,直接{{变量}}

(2)作用于组件属性

<!-- 2.作用于属性 -->
<view id='item-{{id}}'>"作用于属性"</view>
 data: {
     id:0
  },

注意:因为外面已经有‘’所以{{}} 不用再包双引号

(3)作用于控制属性

<!-- 作用于控制属性 -->
<view wx:if="{{showLine}}">"showLine决定此行是否展示"</view>
  data: {
     showLine:false
  },

注意: wx:if接受boolean值可以控制组件是否展示

二.运算

可以在{{}}内进行简单的运算,支持如下几种方式:
(1)三元运算

<!-- 4.三元运算 -->
<view hidden='{{showBoolean ? true : false}}'>"showBoolean控制显示"</view>
  data: {
     showBoolean:false
  },

(2)算数运算

<!-- 5.算数运算 -->
<view>{{a+b}}+{{c}}+d</view>
 data: {
      a:1,
      b:2,
      c:3,
      d:4
  },

显示结果:3+3+d

(3)逻辑判断

<!-- 判断逻辑 -->
<view wx:if="{{length>5}}">判断逻辑</view>

(4)字符串运算

<!-- 7.字符串运算 -->
<view >{{"hello"+title}}</view>
  data: {
      title:"标题"
  },

显示结果:hello标题

三.组合

可以在Mustache内直接进行组合,构成新的对象或者数组
(1)数组组合

<!--8. 数组组合 -->
<view wx:for="{{[zero,1,2,3,4]}}">{{item}}</view>
data: {
   zero:0
  },
显示结果:0,1,2,3,4

(2)对象组合

<!--9. 对象组合 -->
<template data="{{for:a,bar:b}}"></template>

data接受一个对象因为已经有了两个大括号了,不必再写第三个括号,直接写key 和value,for为key ,a为值 a 这个值就会去js中data里面去找,bar为key ,b为值 也会去js中data里面去找,两者组合在一个对象里面。
(2)对象展开
也可以用扩展运算符 ...来将一个对象展开

<!--10.扩展对象 -->
<template data="{{...bean1,...bean2,e:5}"></template>
data: {
    bean1: {
      a: 1,
      b: 2
    },
    bean2: {
      c: 1,
      d: 2

    }
  },

组合结果:1,2,1,2,5

如果对象的key和value相同,也可以间接的表达

<template data="{{a,b}}"></template>
data: {
    a: 1,
    b: 2
}

对象组合:{a:1,b:2}

上述方式可以随意组合,但是如有存在变量名相同的情况,后边的会覆盖前面的

四.条件渲染

wx:if
在框架中,我们用wx:if="{{condition}}"来判断是否要渲染该代码

<view wx:if="{{showLine}}">"showLine决定此行是否展示"</view>

也可以用wx:elif 和wx:else来添加else块

<view wx:if="{{d<2}}">展示1</view>
<view wx:elif="{{d<3}}">展示2</view>
<view wx:else="{{d<6}}">展示3</view>

显示结果:展示3

block wx:if

因为wx:if是一个控制属性,需要将它添加到一个标签上,但是如果我们想一次性的判断多个组件标签,我们可以使用一个<block/>标签将多个组件包裹起来,并在上边使用wx:if控制属性

<!-- block标签 -->
<block wx:if="{{true}}">
<view >展示1</view>
<view >展示2</view>
</block>

注意<block/>并不是一个组件,它仅仅是一个包装元素,不会在页面中做任何渲染,只接受控制属性。

这里面的block 可以用view 代替,但是用block就是不会渲染,展示页面会更快

五.列表渲染

wx:for
在组件上使用wx:for控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件,默认数组的当前想的小标变量默认为index,数组当前项的变量名默认为item

<!-- 列表渲染 -->
<view wx:for="{{list}}">
  <view>{{index}}:{{item}}</view>
</view>
data:{
  list:[
      "元素1",
      "元素2",
      "元素3",
      "元素4"
    ]
}

使用wx:for-item可以指定数组当前元素的变量名
使用wx:for-index可以指定数组当前下标的变量名

<!-- 列表渲染 -->
<view wx:for="{{list}}" wx:for-index="in"  wx:for-item="ite">
<view>{{in}}:{{ite}}</view>
</view>

wx:for 也可以嵌套,下边是个九九乘法表

<view wx:for="{{[1,2,3,4,5,6,7,8,9]}} "  wx:for-item="i">
<view wx:for="{{[1,2,3,4,5,6,7,8,9]}} " wx:for-item="j">
  <view wx:if="{{ i <= j}}">{{i}} * {{j}} ={{i*j}}</view>
</view>
</view>

block:wx:for
类似block:wx:if ,也可以将wx:for用在<block/>标签上,以渲染一个包含多个节点的结构块,例如:

<view wx:for="{{list}} " >
  <view>{{index}}:</view>
  <view>{{item}}</view>
</view>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352