为什么需要将属性导出
在进行QML应用开发时,很多时候都是以组件的形式规划软件的,然而一个组件又由许多子元素组成和描述。当我们需要从一个组件引用另一个组件的属性时,这时候就需要将被引用组件的属性导出。例如:当一个组件是由数据驱动的,那么就必须将被数据驱动的属性导出,供其他组件引用使用和修改。
属性导出
将一个组件的属性导出,有两种形式:
(1)自定义属性。
(2)属性别名。
为一个组件类型自定义属性,其语法格式为:
【readonly】property
property是固定写法。
自定义的属性默认有一个属性值改变信号,我们可以使用on
propertyaliaslabel:labelText.text propertycolortint:"blue" onLabelChanged:console.log("aliasLabelChanged") onTintChanged:console.log("tintChanged")
上述代码中,onLabelChanged信号处理程序用于接收label的改变信号;onTintChanged用于接收Tint的改变信号。
为一个组件定义一个属性别名,写法如下所示:
[default]propertyalias:
property alias是标准写法,不能更改。
声明属性别名与普通的属性定义类似,只是它需要alias关键字而不是属性类型,并且属性声明的右侧必须是一个有效的别名引用。
例如:
propertyaliasbutton:item.button
上述代码中,别名则是指item组件实例中的按钮组件实例。
在 Qt Design Studio和QtCreate设计模式中,我们可以使用Navigator中的(Export)按钮将组件导出为具有有效别名引用的属性名:

注:导出的属性可以在『Connections』视图下的Properties中查看。
注:在其他文件代码中使用的组件必须导出为属性。
注:在QtCreator设计模式下导出组件属性的方法与Qt Design Studio是一样的。
一个实例
看一个具体实例,下面代码是自定义的一个按钮(Button):
importQtQuick2.0
Item{
id:container
propertyaliaslabel:labelText.text
propertycolortint:"blue"
signalclicked
width:labelText.width+70;height:labelText.height+18
BorderImage{
anchors{fill:container;leftMargin:-6;topMargin:-6;rightMargin:-8;bottomMargin:-8}
source:'images/box-shadow.png'
border.left:10;border.top:10;border.right:10;border.bottom:10
}
Image{anchors.fill:parent;source:"images/cardboard.png";antialiasing:true}
Rectangle{
anchors.fill:container;color:container.tint;visible:container.tint!=""
opacity:0.25
}
Text{id:labelText;font.pixelSize:15;anchors.centerIn:parent}
MouseArea{
anchors{fill:parent;leftMargin:-20;topMargin:-20;rightMargin:-20;bottomMargin:-20}
onClicked:container.clicked()
}
}
上述代码中,自定义按钮的height、width参数由labelText标签文本来确定,然后创建一个Rectangle用于显示按钮颜色,创建MouseArea用于接收鼠标的点击事件,并定义了一个clicked信号:
signalclicked
在MouseArea类型的点击事件处理程序中发出该信号:
MouseArea{
anchors{fill:parent;leftMargin:-20;topMargin:-20;rightMargin:-20;bottomMargin:-20}
onClicked:container.clicked()
}
使用Image类型导入一张图片,作为按钮的背景:
Image{anchors.fill:parent;source:"images/cardboard.png";antialiasing:true}
因为按钮的文本和颜色需要被其他组件类型控制(即,在其他组件的属性绑定或逻辑处理中需要改变按钮的文本和颜色值),所以添加了一个颜色属性(用于表示按钮的颜色)和label别名(引用labelText元素的text属性):
//label别名 propertyaliaslabel:labelText.text //颜色属性 propertycolortint:"blue"
通过上述代码,将属性导出后,在其他组件类型中则可通过label和tint访问按钮组件内的属性。
在设计中,有效的别名引用有以下几个特性(以上述例子中代码为例):
(1)只能指向声明了属性别名的组件中的组件实例或属性。
(2)不能包含JavaScript表达式。例如下列写法是错误的:
propertyaliaslabel:console.log("clicked")
(3)除了声明属性别名的组件外,不能指向其他类型的组件。
(4)不能指向附加的属性。
在别名引用的写法格式上,别名引用必须指定为:
以下几种写法都是错误的:
propertyaliaslabel:myName propertystringmyName:"iriczhao"
上述代码位置交换一下也是错误的。下列从根元素(container为根元素的id)引用的写法也是错误的:
propertystringmyName:"iriczhao" propertyaliaslabel:container.myName
(5)不能引用深度超过3层的嵌套属性。例如下列错误的用法:
//该属性引用将不能正常工作
propertyaliascolor:myItem.myRect.border.color
Item{
id:myItem
propertyRectanglemyRect
}
审核编辑:刘清
-
数据驱动
+关注
关注
0文章
165浏览量
12735
原文标题:qml属性导出
文章出处:【微信号:嵌入式小生,微信公众号:嵌入式小生】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
ADC12D1620QML-SP技术手册
LM136A-2.5QML/LM136A-2.5QML-SP 技术文档摘要
LM4050QML精密微功耗并联电压基准芯片技术文档总结
凡亿Allegro Skill工艺辅助之导出公制的坐标
PADS导出.318文件遗漏器件
STM32CubeMx使用ADC时,只需要将通道进行配置,不需要对引脚进行模拟输入吗?
LM5175的四开关管升降压开关电源,导出的原理图中有六个开关管,为什么M3、M4各自需要并联一个一样的开关管呢?
DLP NIRscan Nano GUI只是采集光谱数据?导出的数据,需要自行建模吗?
深入探索GCC的attribute属性
ADC08D1520QML可以采集到的最高频率是多少?
如何导出交换机的配置文件
Chart FX——图表导出
Chart FX-使用API传输数据 使用Value属性传输数据

为什么需要将QML的属性导出呢
评论