QML- 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
}

相比之下,对象类型的属性会发出自己的属性更改信号,并且只有在将属性重新分配给不同的对象值时,才会调用对象类型属性的属性更改信号处理程序。

猜你喜欢

转载自blog.csdn.net/qq_43680827/article/details/129544616
QML