• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >微信小程序 > 微信小程序之视图层WXML绑定数据、模板、逻...

微信小程序之视图层WXML绑定数据、模板、逻...

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-11-30

匿名通过本文主要向大家介绍了微信小程序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
前篇文章介绍了小程序的MVC结构:

page.js 即控制层(C),也叫业务逻辑层;

page.js 中的data属性,即数据模型层(M);

page.wxml 即展现层(V);

page.wxss 即css,增强展现层效果。


通过业务逻辑层(C),修改data属性(M),从而在展现层(V)中展示。

即MVC设计模式。


一、数据绑定

首先看一下Page页面的MVC 流程结构图

微信小程序之视图层WXML绑定数据、模板、逻...

如果在 data 中定义了某个变量,比如

Page({
    data:{
        title: '小程序实战教程',
        desc: '视图层—WXML'
    }
})

在页面中通过 {{title}},即可展示效果,如下动图:

微信小程序之视图层WXML绑定数据、模板、逻...

二、数据绑定常用语法

2.1,内容

<view> {{ message }} </view>


2.2,组件属性(需要在双引号之内)

和内容一样

<view id="item-{{id}}"> </view>


2.3,控制属性

<view wx:if="{{condition}}"> </view>


2.4,关键字(需要{{ }}内)

true:boolean 类型的 true,代表真值。

false: boolean 类型的 false,代表假值。

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

注意:不要直接写 checked="false",其计算结果是一个字符串,转成 boolean 类型后代表真值。


2.5,三元运算
<view hidden="{{flag ? true : false}}"> Hidden </view>


2.6,算数运算
<view> {{a + b}} + {{c}} + d </view>


2.7,字符串运算
<view>{{"hello" + name}}</view>


2.8,数据路径运算

对于object类型,可以通过object.key获取值;

对于array类型,可以通过下标index获取值,index从0开始

<view>{{object.key}} {{array[0]}}</view>


代码和效果图:

微信小程序之视图层WXML绑定数据、模板、逻...

微信小程序之视图层WXML绑定数据、模板、逻...

三、逻辑渲染语法
3.1,逻辑判断 wx:if
<view wx:if="{{length > 5}}"> </view>

或者

<view wx:if="{{length > 5}}"> 1 </view>
<view wx:elif="{{length > 2}}"> 2 </view>
<view wx:else> 3 </view>


block wx:if

<block wx:if="{{true}}">
<view> view1 </view>
<view> view2 </view>
</block>


3.2,wx:for

默认数组的当前项的下标变量名默认为 index,数组当前项的变量名默认为 item 。也可以通过 wx:for-index 和 wx:for-item 指定。

<view wx:for="{{array}}">
{{index}}: {{item.message}}
</view>


指定

<view wx:for="{{array}}" wx:for-index="idx"wx:for-item="itemName">
{{idx}}: {{itemName.message}}
</view>


block wx:for

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


3.3,wx:key

如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如 <input/> 中的输入内容,<switch/> 的选中状态),需要使用 wx:key 来指定列表中项目的唯一的标识符。

wx:key 的值以两种形式提供

1)字符串,代表在 for 循环的 array 中 item 的某个 property,该 property 的值需要是列表中唯一的字符串或数字,且不能动态改变。

2)保留关键字 *this 代表在 for 循环中的 item 本身,这种表示需要 item 本身是一个唯一的字符串或者数字


当数据改变触发渲染层重新渲染的时候,会校正带有 key 的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态,并且提高列表渲染时的效率。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2018-11-30小程序开发之基础篇滑动操作(10)
  • 2018-11-30关于itchat的详细介绍
  • 2018-08-20微信小程序 基础组件
  • 2018-11-30小程序开发之天气预报
  • 2018-11-30微信小程序中如何实现列表渲染多层嵌套循环
  • 2018-11-30微信小程序“圣诞帽”的实现方法
  • 2018-11-23微信小程序云开发API 获取记录数据
  • 2018-11-30干货:小程序开发文档和设计指南要点详解
  • 2018-11-23微信小程序云开发服务端数据库API 更新一条记录
  • 2018-11-30小程序中多滑块的实现代码

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 微信小程序中数据缓存的解析
    • 微信小程序可开发实例:豆瓣图书小程序
    • 微信小程序中选项卡的实现方法
    • 微信小程序window_x64环境搭建详细介绍
    • 关于微信小程序中框架的解析
    • 微信小程序 教程之条件渲染
    • 微信小程序城市定位的实现
    • 微信小程序中滚动消息通知的实现
    • 2017年最新的小程序功能--“搜索联想区”
    • 微信小程序仿手机淘宝demo代码

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有