QML Basic 基础类型
一、概述
QML支持许多基本类型。
基本类型就是指相对简单值的类型,如int或string。基本类型和对象类型的区别就是,对象类型指的是具有属性、信号、方法等的对象。与对象类型不同,基本类型不能用于声明QML对象:例如,不能声明 int{} 对象或 size{} 对象。
基本类型可以用来引用:
- 单个值(例如 int 指向一个数字,var可以指向一个列表)。
- 包含一组简单的属性值对的值(例如,size 指的是具有 width 和 height 属性的值)。
当变量或属性持有基本类型时,将其赋值给另一个变量或属性时,就会创建该值的副本。在JavaScript中,这个值称为基本值(primitive value)。
二、支持的基本类型
引擎默认支持一些基本类型,不需要使用import语句,而其他类型则需要导入提供它们的模块。下面列出的所有基本类型都可以用作QML文档中的属性类型,但有以下例外:
- list必须与QML对象类型一起使用
- 枚举不能直接使用,因为枚举必须由注册的QML对象类型定义
三、QML语言提供的基本类型
QML语言原生支持的基本类型如下所示。
原生类型 | 解释 |
---|---|
bool | 二进制的真/假值 |
double | 带小数点的数字,以双精度存储 |
enumeration | 枚举值类型 |
int | 整数,如0、10或-20 |
list | QML对象的列表类型 |
real | 有小数点的数就像float |
string | 字符串 |
url | 资源定位符 |
var | 变量类型,泛型属性类型 |
四、QML模块提供的基本类型
QML模块可以用更基本的类型扩展QML语言。例如,QtQuick模块提供的基本类型如下所示:
原生类型 | 解释 |
---|---|
date | 日期值 |
point | 用x和y属性值 |
rect | 使用x、y、width和height属性值 |
size | 封装的的 width 和 height 属性 |
Qt global对象提供了操作基本类型值的有用函数。
目前Qt提供的QML模块可能会提供自己的基本类型,但这可能会在Qt QML的未来版本中发生变化。为了使用特定QML模块提供的类型,最好必须在其QML文档中导入该模块。
五、基本类型的属性更改行为
一些基本类型也是有属性,例如 font 类型有pixelSize、family和bold属性。
与对象类型的属性不同,基本类型的属性不提供自己的属性变化信号。只能为基本类型属性本身创建一个属性更改信号处理程序,也就是说,这类的属性变化不能精确到基本类型的属性,只能到第一级,不能到第二级:
Text {
// 非法!
onFont.pixelSizeChanged: doSomething()
// also 非法!
font {
onPixelSizeChanged: doSomething()
}
// OK的
onFontChanged: doSomething()
}
不过,需要注意的是,只要基本类型的任何属性发生了变化,以及属性本身发生了变化,就会发出属性变化信号。以以下代码为例:
Text {
onFontChanged: console.log("font changed")
Text {
id: otherText }
focus: true
// changing any of the font attributes, or reassigning the property
// to a different font value, will invoke the onFontChanged handler
Keys.onDigit1Pressed: font.pixelSize += 1
Keys.onDigit2Pressed: font.b = !font.b
Keys.onDigit3Pressed: font = otherText.font
}
相比之下,对象类型的属性会发出自己的属性更改信号,并且只有在将属性重新分配给不同的对象值时,才会调用对象类型属性的属性更改信号处理程序。