介绍组件构造,销毁,动态加载小知识。
对象/组件都具有类似C++的构造函数和析构函数
onCompleted
对象构造完成自动执行;onDestruction
对象销毁前自动执行。1
2
3
4QtObject {
Component.onCompleted: console.log("Completed")
Component.onDestruction: console.log("Destruction")
}
使用Loader加载组件
Component
必须具有子空间才能实例化;onProgressChanged
可以获取到组件的加载进度。1
2
3
4
5
6
7
8
9
10
11Component {
id: component
Text {
text: "Component"
}
}
Loader {
sourceComponent: component
onProgressChanged: console.log(progress)
}
动态加载Qml组件(1)
- 原型:
qml
为qml组件描述语句;parent
为依附于那个父类控件;filepath
为重定向到文件的加载过程中的错误报告1
2
3object createQmlObject(qml,
object parent,
string filepath)
- 例子
1
2
3var object = Qt.createQmlObject('import QtQuick 2.0; Rectangle {color: "blue"; width: 50; height: 50}',
root,
"error.txt");
动态加载Qml组件(2)
- 原型:
url
为qml文件(还可以加载网络qml文件);mode
为创建qml的模式(同步或异步);parent
指定某个控件为父类控件;object
为附加属性。1
2object createComponent(url, mode, parent)
object createObject(parent, object properties)
- 示例:
1
2
3var component = Qt.createComponent("MyComponent.qml");
if (component.status == Component.Ready)
component.createObject(parent, {x: 100, y: 100});