Qt 学习之路 :Repeater
前面的章节我们介绍过模型视图。这是一种数据和显示相分离的技术,在 Qt 中有着非常重要的地位。在 QtQuick 中,数据和显示的分离同样也是利用这种“模型-视图”技术实现的。对于每一个视图,数据元素的可视化显示交给代理完成。与 Qt/C++ 类似,QtQuick 提供了一系列预定义的模型和视图。本章开始,我们着重介绍这部分内容。这部分内容主要来自http://qmlbook.org/ch06/index.html,在此表示感谢。
由于 QtQuick 中的模型视图的基本概念同前面的章节没有本质的区别,所以这里不再赘述这部分内容。
将数据从表现层分离的最基本方法是使用Repeater元素。Repeater元素可以用于显示一个数组的数据,并且可以很方便地在用户界面进行定位。Repeater的模型范围很广:从一个整型到网络数据,均可作为其数据模型。
Repeater最简单的用法是将一个整数作为其model属性的值。这个整型代表Repeater所使用的模型中的数据个数。例如下面的代码中,model: 10代表Repeater的模型有 10 个数据项。
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | import QtQuick 2.2 Column {     spacing: 2     Repeater {         model: 10         Rectangle {             width: 100             height: 20             radius: 3             color: "lightBlue"             Text {                 anchors.centerIn: parent                 text: index             }         }     } } | 
现在我们设置了 10 个数据项,然后定义一个Rectangle进行显示。每一个Rectangle的宽度和高度分别为 100px 和 20px,并且有圆角和浅蓝色背景。Rectangle中有一个Text元素为其子元素,Text文本值为当前项的索引。代码运行结果如下:

虽然指定模型项的个数很简单,但实际用处不大。Repeater还支持更复杂的方式,例如,把一个 JavaScript 数组作为模型。JavaScript 数组元素可以是任意类型:字符串、数字或对象。在下面的例子中,我们将一个字符串数组作为Repeater的模型。我们当然可以使用index获得当前索引,同时,我们也可以使用modelData访问到数组中的每一个元素的值:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | import QtQuick 2.2 Column {     spacing: 2     Repeater {         model: ["Enterprise", "Colombia", "Challenger", "Discovery", "Endeavour", "Atlantis"]         Rectangle {             width: 100             height: 20             radius: 3             color: "lightBlue"             Text {                 anchors.centerIn: parent                 text: index +": "+modelData             }         }     } } | 
代码运行结果如下:
由于能够使用 JavaScript 数组作为Repeater的模型,而 JavaScript 数组能够以对象作为其元素类型,因而Repeater就可以处理复杂的数据项,比如带有属性的对象。这种情况其实更为常见。相比普通的 JavaScript 对象,更常用的是ListElement类型。类似普通 JavaScript 对象,每一个ListElement可以有任意属性。例如下面的代码示例中,每一个数据项都有一个名字和外观颜色。
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | import QtQuick 2.2 Column {     spacing: 2     Repeater {         model: ListModel {             ListElement { name: "Mercury"; surfaceColor: "gray" }             ListElement { name: "Venus"; surfaceColor: "yellow" }             ListElement { name: "Earth"; surfaceColor: "blue" }             ListElement { name: "Mars"; surfaceColor: "orange" }             ListElement { name: "Jupiter"; surfaceColor: "orange" }             ListElement { name: "Saturn"; surfaceColor: "yellow" }             ListElement { name: "Uranus"; surfaceColor: "lightBlue" }             ListElement { name: "Neptune"; surfaceColor: "lightBlue" }         }         Rectangle {             width: 100             height: 20             radius: 3             color: "lightBlue"             Text {                 anchors.centerIn: parent                 text: name             }             Rectangle {                 anchors.left: parent.left                 anchors.verticalCenter: parent.verticalCenter                 anchors.leftMargin: 2                 width: 16                 height: 16                 radius: 8                 border.color: "black"                 border.width: 1                 color: surfaceColor             }         }     } } | 
运行结果如下图所示:

ListElement的每个属性都被Repeater绑定到实例化的显示项。正如上面代码中显示的那样,这意味着每一个用于显示数据的Rectangle作用域内都可以访问到ListElement的name和surfaceColor属性。
像上面几段代码中,Repeater的每一个数据项都使用一个Rectangle渲染。事实上,这是由于Repeater具有一个delegate的默认属性,由于Rectangle没有显式赋值给任何一个属性,因此它直接成为默认属性delegate的值,所以才会使用Rectangle渲染。理解了这一点,我们就可以写出具有显式赋值的代码:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | import QtQuick 2.2 Column {     spacing: 2     Repeater {         model: 10         delegate: Rectangle {             width: 100             height: 20             radius: 3             color: "lightBlue"             Text {                 anchors.centerIn: parent                 text: index             }         }     } } | 
实际上,这段代码与前面提到的是等价的。
Qt 学习之路 :Repeater的更多相关文章
- 《Qt 学习之路 2》目录
		<Qt 学习之路 2>目录 <Qt 学习之路 2>目录 豆子 2012年8月23日 Qt 学习之路 2 177条评论 <Qt 学习之路 2>目录 序 Qt ... 
- QT学习之路--创建一个对话框
		Q_OBJECT:这是一个宏,凡是定义信号槽的类都必须声明这个宏. 函数tr()全名是QObject::tr(),被他处理过的字符串可以使用工具提取出来翻译成其他语言,也就是做国际化使用. 对于QT学 ... 
- 转载: Qt 学习之路 2归档
		Qt 学习之路 2归档 http://www.devbean.net/2012/08/qt-study-road-2-catelog/ 
- Qt学习之路
		Qt学习之路_14(简易音乐播放器) Qt学习之路_13(简易俄罗斯方块) Qt学习之路_12(简易数据管理系统) Qt学习之路_11(简易多文档编辑器) Qt学习之路_10(Qt ... 
- Qt 学习之路 2
		Qt 学习之路 2 | DevBean Tech World Qt 学习之路 2 Qt 学习之路 2 目录 
- Qt 学习之路 2(76):QML 和 QtQuick 2
		Home / Qt 学习之路 2 / Qt 学习之路 2(76):QML 和 QtQuick 2 Qt 学习之路 2(76):QML 和 QtQuick 2 豆子 2013年12月18日 Qt ... 
- Qt 学习之路 2(74):线程和 QObject
		Home / Qt 学习之路 2 / Qt 学习之路 2(74):线程和 QObject Qt 学习之路 2(74):线程和 QObject 豆子 2013年12月3日 Qt 学习之路 2 2 ... 
- Qt 学习之路 2(73):Qt 线程相关类
		Home / Qt 学习之路 2 / Qt 学习之路 2(73):Qt 线程相关类 Qt 学习之路 2(73):Qt 线程相关类 豆子 2013年11月26日 Qt 学习之路 2 7条评论 希 ... 
- Qt 学习之路 2(72):线程和事件循环
		Qt 学习之路 2(72):线程和事件循环 <理解不清晰,不透彻> -- 有需求的话还需要进行专题学习 豆子 2013年11月24日 Qt 学习之路 2 34条评论 前面一章我 ... 
- Qt 学习之路 2(71):线程简介
		Qt 学习之路 2(71):线程简介 豆子 2013年11月18日 Qt 学习之路 2 30条评论 前面我们讨论了有关进程以及进程间通讯的相关问题,现在我们开始讨论线程.事实上,现代的程序中,使用线程 ... 
随机推荐
- 浅析tornado web框架
			tornado简介 1.tornado概述 Tornado就是我们在 FriendFeed 的 Web 服务器及其常用工具的开源版本.Tornado 和现在的主流 Web 服务器框架(包括大多数 Py ... 
- WPF Navigation导航
			WPF导航这个话题,网上的解决方法有很多种,有点吃猪脚的感觉,弃之可惜,食之乏味. 不过还是简单聊聊吧. 常见的导航: 利用HyperLink导航,可以到某一个Page页面,也可以是外部链接,当然也可 ... 
- 计算机视觉的matlab工具箱及MVG等
			MATLAB Functions for Multiple View Geometry Peter Kovesi's Matlab functions for Computer Vision Jean ... 
- SignalR介绍与Asp.net,前台即时通信【转】
			SignalR 是一个asp.net异步库,它提供广播消息到多个client端的机制. SignalR能用来持久客户端与服务端的连接,让我们便于开发一些实时的应用,例如聊天室在线预订系统,股票交易等实 ... 
- TCP连接建立和关闭中的疑难点
			TCP连接建立和关闭中的疑难点 作者:夏语岚 撰写日期:2011-10-29 近日在阅读<Unix网络编程>,以前在<计算机网络>课程中学到TCP,当时只是简单了解了TC ... 
- 随时可以给doT模板传任何你想要的值
			我以前一直以为只有传给后台的数据才能用doT模板写入, 其实,随时可以把本地处理的数据,仅仅的一个变量,改头换面成一个it关键字下面的属性. 方法就是在tpl中给它赋值. 要注意的是,首先tpl中的属 ... 
- GNOME Shell叫板Ubuntu Unity:优劣PK
			转自GNOME Shell叫板Ubuntu Unity:优劣PK GNOME Shell 对阵 Ubuntu Unity--默认桌面界面的战火一触即发.双方在台上已经对峙了很长时间,现在是时候决定谁会 ... 
- Jetty实战之 安装 运行 部署
			本文地址:http://blog.csdn.net/kongxx/article/details/7218767 1. 首先从Jetty的官方网站http://wiki.eclipse.org/Jet ... 
- java rest版简单的webservice
			目前的webservice风格,rest应该是其中一种 还有种就是soap,rest是轻量级的,越来越流行.下面举一个简单例子说明下rest的用法. 1. 准备ws的jar和spring的jar,如何 ... 
- Unicode(UTF-8, UTF-16)令人混淆的概念
			为啥需要Unicode 我们知道计算机其实挺笨的,它只认识0101这样的字符串,当然了我们看这样的01串时肯定会比较头晕的,所以很多时候为了描述简单都用十进制,十六进制,八进制表示.实际上都是等价的, ... 
