🚀WXML语法:带你进入前端开发的快车道!

简介: 【2月更文挑战第3天】

WXML

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


数据绑定

WXML 中的动态数据均来自对应js文件中 Page 的 data。

数据绑定就是通过双大括号({{ }})将变量包起来,在wxml页面里将数据值显示出来。

简单绑定

<!--wxml-->
<view> {{message}} </view>
// page.js
Page({
  data: {
    message: 'Hello MINA!'
  }
})

组件属性绑定

它是将data 里的数据绑定到微信小程序的组件上。

<!--wxml-->
<view id="item-{{id}}"></view>
// page.js
Page({
data:{
id:0
}
})

控制属性绑定

它用来进行if语句条件判断,如果条件满足,则执行,否则反之。

<!--wxml-->
<view wx:if="{{condition}}"> </view>
Page({
  data: {
    condition: true
  }
})

关键字绑定

常用于组件的一些关键字

像复选框组件一样,checked 关键字如果为 TRUE,则代表复选框选中,如果等于FALSE,则代表不选中复选框。

<checkbox checked="{{false}}"> </checked>

条件渲染

wx:if 判断单个组件

判断是否需要喧染该代码块

<!--wxml-->
<view wx:if="{{view == 'WEBVIEW'}}"> WEBVIEW </view>
<view wx:elif="{{view == 'APP'}}"> APP </view>
<view wx:else="{{view == 'MINA'}}"> MINA </view>
// page.js
Page({
  data: {
    view: 'MINA'
  }
})

block wx:if判断多个组件

<block wx:if="{{true}}">
<view>flag1</view>
<view>flag2</view>
</block>

<block/>不是一个组件,他是一个包装元素,不会在页面做任何喧染,只接受控制属性。

<button bindtap="change_color">横条变色</button>
<block wx:if="{{b==true}}">
<view class="bg_green"></view>
</block>
<block wx:elif="{{b==false}}">
<view class="bg_blue"></view>
</block>
Page({
  data:{
    b:false
    },
    change_color:function(){
      var ab=this.data.b;
      this.setData({
        b:!ab
      })
    }
})
.bg_green{
  height: 100px;
  background-color: green;
}
.bg_blue{
  height: 100px;
  background-color: blue;
}

运算

三元运算

<view hidden ="{{flag? true:false}}">Hidden</view>

数学运算

<view>{{a+b}}+{{c}}+d</view>
Page({
data:{
a:1,
b:2,
c:3
}
})

逻辑判断

<view wx:if="{{length>5}}"></view>

字符串运算

<view>{{"hello"+name}}</view>
Page({
data:{
name:'weixing'
}
})

数据路径运算

<view>{{object.key}}{{arr[0]}}</view>
Page({
data:{
object:{
key:'nihao'
},
arr:['hello']
}
})

列表渲染

wx:for 列表渲染单个组件

在组件上使用wx:for控制属性绑定一个数组,即可使用数组中的各项的数据重复渲染该组件。

<view wx:for="{{array}}">
{{index}}:{{item.message}}
</view>
等价于
<view wx:for="{{array}}" wx:for-index="idx"
 wx:for-item="itemName">
{{idx}}:{{itemName.message}}
</view>
Page({
data:{
array:[
{
message:'第0个元素'
},{
message:'第1个元素'
}
]
}
})

block wx:for列表渲染多个组件

<block wx:for="{{[1,2,3]}}">
<view>{{index}}:</view>
<view>{{item}} </view>
</block>

wx:key指定唯一标识符

如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己得特征和状态,需要使用wx:for来指定列表中的项目的唯一标识符。

<input/>中输入的内容
<switch/>中选中的状态

<switch wx:for="{{objectArray}}" wx:key="unique">{{item.id}}</switch>
Page({
data:{
objectArray:[
{id:5,unique:"five"},
{id:4,unique:"four"},
{id:3,unique:"three"}
]
}
})

如果不提供wx:key,会有一个warning,如果明确知道该列表是静态的,或者不必关注其顺序,可以选择忽略。

目录
相关文章
|
4月前
|
前端开发 程序员
【前端web入门第二天】01 html语法实现列表与表格_合并单元格
本文介绍了HTML中的列表与表格的使用方法。列表包括无序列表(`&lt;ul&gt;`嵌套`&lt;li&gt;`)、有序列表(`&lt;ol&gt;`嵌套`&lt;li&gt;`)和定义列表(`&lt;dl&gt;`嵌套`&lt;dt&gt;`和`&lt;dd&gt;`)。
74 19
|
4月前
|
前端开发 程序员 C++
【前端web入门第一天】01 开发环境、HTML基本语法文本标签
本文档详细介绍了HTML文本标签的基础知识。首先指导如何准备开发环境,包括安装VSCode及常用插件;接着全面解析HTML的基本结构与标签语法,涵盖从基本骨架搭建到注释的使用,以及标题、段落、换行和平行线、文本格式化等标签的具体应用,适合初学者循序渐进地掌握HTML。
|
5月前
|
缓存 前端开发 Java
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
【8月更文挑战第10天】java基础巩固,工具类的封装
30 1
|
5月前
|
存储 前端开发 JavaScript
【前端学JAVA】有手就会!10min快速入门java的基础语法(2)
【8月更文挑战第8天】10min快速入门java的基础语法
46 2
【前端学JAVA】有手就会!10min快速入门java的基础语法(2)
|
5月前
|
前端开发 JavaScript 程序员
前端 JavaScript 的 _ 语法是个什么鬼?
前端 JavaScript 的 _ 语法是个什么鬼?
|
6月前
|
缓存 JavaScript 前端开发
前端框架与库 - Vue.js基础:模板语法、数据绑定
【7月更文挑战第14天】Vue.js 是渐进式框架,以简洁API和高效数据绑定知名。本文聚焦模板语法与数据绑定,解释常见问题和易错点,助力初学者避坑。模板语法中,{{ expression }} 用于渲染值,v-bind/: 用于动态绑定属性。数据绑定涉及文本、属性和事件,注意v-model适用于表单元素,计算属性有缓存。理解正确用法,借助文档和IDE,可提升开发质量和效率。善用Vue.js,打造响应式UI。
176 4
|
7月前
|
前端开发 JavaScript Java
【前端技术】 ES6 介绍及常用语法说明
【前端技术】 ES6 介绍及常用语法说明
57 4
|
7月前
|
存储 缓存 JavaScript
【前端 - Vue】之 Keep-Alive缓存组件使用语法及原理解析,超详细!
【前端 - Vue】之 Keep-Alive缓存组件使用语法及原理解析,超详细!
|
JavaScript 前端开发 API
前端JavaScript入门到精通,javascript核心进阶ES6语法、API、js高级等基础知识和实战 —— JS进阶(三)
前端JavaScript入门到精通,javascript核心进阶ES6语法、API、js高级等基础知识和实战 —— JS进阶(三)
598 1
|
8月前
|
Dart 前端开发 开发者
【Flutter前端技术开发专栏】Flutter Dart语言基础语法解析
【4月更文挑战第30天】Dart是Google为Flutter框架打造的高效编程语言,具有易学性、接口、混入、抽象类等特性。本文概述了Dart的基础语法,包括静态类型(如int、String)、控制流程(条件、循环)、函数、面向对象(类与对象)和异常处理。此外,还介绍了库导入与模块使用,帮助开发者快速入门Flutter开发。通过学习Dart,开发者能创建高性能的应用。
82 0
【Flutter前端技术开发专栏】Flutter Dart语言基础语法解析