http://blog.csdn.net/qidong7/article/details/53244346

源码下载(XiaoDemo-V1.0)
链接:http://pan.baidu.com/s/1i5sLYw1

密码:pzqr

前篇文章介绍了小程序的MVC结构:

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

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

page.wxml 即展现层(V);

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

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

即MVC设计模式。

一、数据绑定

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

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

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

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

二、数据绑定常用语法

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>

代码和效果图:

三、逻辑渲染语法
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 的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态,并且提高列表渲染时的效率。

<switch wx:for="{{objectArray}}"wx:key="unique" style="display: block;"> {{item.id}} </switch>

见图

四、模板

WXML提供模板(template),在不同的地方调用。实现复用的效果。

通过<template/>标签:

定义模板

使用name属性,作为模板的名字。然后在<template/>内定义代码片段。

使用模板

使用 is 属性,声明需要的使用的模板,然后将模板所需要的 data 传入。

代码如下:

定义模板

<template name="myTpl">
  <view>
    <text> {{name}}: {{time}} </text>
  </view>
</template>

使用模板(通过...将对象展开)

<template is="myTpl" data="{{...item}}"/>

注:

1)is 属性可以使用 Mustache 语法,来动态决定具体需要渲染哪个模板

2)模板拥有自己的作用域,只能使用data传入的数据。

五、数据组合

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

data:{

tplItem:{
            name:‘我的模板‘,
            time:‘2016-11-16‘
        }

}

数组

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

对象

<template is="myTpl" data="{{name: title, time: ‘2016-11-16‘}}">

</template>

也可以用扩展运算符 ... 将一个对象展开。

就是展开属性,新加的属性 (如time:2016-11-20),会覆盖tplItem的time。

<template is="myTpl" data="{{...tplItem, time: ‘2016-11-20‘}}">

</template>

程序员实战技能,扫一扫学习

时间: 2024-10-26 10:51:25

http://blog.csdn.net/qidong7/article/details/53244346的相关文章

中文录入问题 转载自:http://blog.csdn.net/ichsonx/article/details/8625925

2.1中文录入问题 默认安装的msysgit的shell环境中无法输入中文,为了能在shell界面输入中文,需要修改配置文件/etc/inputrc,增加或修改相关配置如下: #disable/enable 8bit input set meta-flag on set input-meta on set output-meta on set convert-meta off 关闭bash再重启就可以输入中文了. 2.2分页器中文输出问题 对于/etc/inputrc正确配置之后能正确输入中文了

VMware下Ubuntu与宿主Windows共享文件夹 (转至 http://blog.csdn.net/zz962/article/details/7706755)

概述1.安装VMware Tool2.设置共享 步骤开始安装VMware Tool 显示如下画面(如果宿主无法访问外网,可能会出现一个更新失败,可以无视之) 通过下列命令解压.执行,分别是下面的tar和sudo的两行(下面是已有vmware tool的情况,注意密码是登录口令,不会显示) 一路按Enter,最后得到 在VMware中给虚拟机设置共享目录 执行mount命令(下图中sudo mount那一行),之后mnt/hgfs里就可以看到前面设置的共享目录 如果mnt出错,可以执行 sudo

解析Javascript事件冒泡机制(转) 本文转自:http://blog.csdn.net/luanlouis/article/details/23927347

本文转自:http://blog.csdn.net/luanlouis/article/details/23927347 1. 事件 在浏览器客户端应用平台,基本生都是以事件驱动的,即某个事件发生,然后做出相应的动作. 浏览器的事件表示的是某些事情发生的信号.事件的阐述不是本文的重点,尚未了解的朋友,可以访问W3school教程 进行了解,这将有助于更好地理解以下的内容 . 2. 冒泡机制 什么是冒泡呢? 下面这个图片大家应该心领神会吧,气泡从水底开始往上升,由深到浅,升到最上面.在上升的过程中

第十八章 并发登录人数控制——《跟我学Shiro》(http://blog.csdn.net/lhacker/article/details/19334305)

第十八章 并发登录人数控制——<跟我学Shiro> 博客分类: 跟我学Shiro 跟我学Shiro 目录贴:跟我学Shiro目录贴 在某些项目中可能会遇到如每个账户同时只能有一个人登录或几个人同时登录,如果同时有多人登录:要么不让后者登录:要么踢出前者登录(强制退出).比如spring security就直接提供了相应的功能:Shiro的话没有提供默认实现,不过可以很容易的在Shiro中加入这个功能. 示例代码基于<第十六章 综合实例>完成,通过Shiro Filter机制扩展Ki

Windows下QT4.8.4编译环境的搭建(转载http://blog.csdn.net/bestgonghuibin/article/details/38933141)

开始使用QT了,所以第一步就是把环境搭起来,这里小记一下,以免以后忘记. 1. 下载安装文件 要使用QT功能,那么必须要下载QT的源码,还必须要一个是用QT的编译环境,可以是VS2010,也可以是专用于QT编程的QT Creator.本人选择QT Creator,所以也必须要下载QT Creator. 根据网上大部分教程及自己买的书籍获取的信息,在选择版本的时候,QT 源码选择4.8.4,而QT Creator选择2.8.0(QT5.0以后许多原有的文件路径改变). 选择好版本之后,可以上QT的

http://blog.csdn.net/wzlas111/article/details/39741091

转载:http://blog.csdn.net/wzlas111/article/details/39741091 Android TV上的焦点凸显特效相信大家都看到过,那么我们就来实现它吧,首先上张效果图. 先说一下实现原理,主要通过重写RelativeLayout实现item,之后在其中加入scalanimation动画效果.刚开始处理时,还是发现了一些问题,比如item放大后会被其他item遮挡,如何添加选中边框等等,以及动画的实现等等.下面放上实现细节. 首先是item的代码: [htm

Android APK反编译详解(附图) (转至 http://blog.csdn.net/ithomer/article/details/6727581)

本文Android反编译教程,测试环境: Win7 Ultimate x64 Ubuntu 12.04 x86_x64 反编译工具包 下载 (2012-10-10更新) 一.Apk反编译得到Java源代码 下载上述反编译工具包,打开apk2java目录下的dex2jar-0.0.9.9文件夹,内含apk反编译成java源码工具,以及源码查看工具. apk反编译工具dex2jar,是将apk中的classes.dex转化成jar文件 源码查看工具jdgui,是一个反编译工具,可以直接查看反编译后的

ABAP面试经历【转http://blog.csdn.net/tsj19881202/article/details/8792742】

本周三面试了一次HP的globe部门,整个过程自己感觉特别糟糕.总结了一下经验, 1.不能把自己平时做的东西,很好的用语言描述出来 2.技术点其实都会,但是不了解对方问题的意思,所以没能很好的回答对方的问题.比如问对方dialog有几个事件,我只记得有pai,pbo.其实f1和f4事件也是.但是我没有意识到.诸如此类的问题有很多. 3. 简历上一定要真实的经验.比如我简历上写了逻辑数据库知识,但是这个跟我理解的是有差别的. 以下是我面试的一些题目.只做参考 开始,就是英文的自我介绍,大致讲一下自

一致性hash 参考:http://blog.csdn.net/cywosp/article/details/23397179/

hash好坏的四个定义: 平衡性:平衡性是指哈希的结果能够尽可能分布到所有的缓冲中去,这样可以使得所有的缓冲空间都得到利用. 单调性:单调性是指如果已经有一些内容通过哈希分派到了相应的缓冲中,又有新的缓冲加入到系统中.哈希的结果应能够保证原有已分配的内容可以被映射到原有的或者新的缓冲中去,而不会被映射到旧的缓冲集合中的其他缓冲区. 添加节点后,原有的哈希结果要么不迁移,要么迁移到新的节点,不会迁移到旧的节点.以hash后取模方式为例,增加一个节点(槽),有的键可能分配到旧节点里 分散性:在分布式