我有一个 QML 快速表单,其中有一个图像和一个关联的鼠标区域,如下所示:
// StatusBarForm.ui.qml
Image {
id: exitButton
width: 24
height: 24
anchors.verticalCenter: parent.verticalCenter
anchors.left: parent.left
anchors.leftMargin: 5
source: "images/exit.png"
MouseArea {
id: exitButtonMouseArea
anchors.fill: parent
}
}
现在,根据文档,我应该将业务逻辑分开,设计师创建了一个StatusBar.qml
表单,我添加了:
exitButtonMouseArea.onClicked: {
Qt.quit()
}
现在问题是我在 Mac 上使用 Qt 5.9 对其进行了测试并且它工作正常(尽管 Qt 创建者强调了onClicked
抱怨的处理程序exitButtonMouseArea identifier was not valid
。我也尝试过exitButton.exitButtonMouseArea.onClicked:
现在我Qt 5.8
在 Linux 上试了一下,应用程序没有初始化。如果我删除事件处理程序,那很好,当然我不能与图像交互。
所以,我的问题是如何在我的情况下提供 UI 文件之外的业务逻辑。
编辑 在@derM 回答之后,我做了以下事情:
// StatusBarForm.ui.qml
Image {
id: exitButton
width: 24
height: 24
anchors.verticalCenter: parent.verticalCenter
anchors.left: parent.left
anchors.leftMargin: 5
source: "images/exit.png"
}
// StatusBar.qml
StatusBarForm {
property alias exitButton: exitButton
Image {
id: exitButton
MouseArea {
id: exitButtonMouseArea
anchors.fill: parent
onClicked: {
Qt.quit()
}
}
}
}
当我的组件初始化时,我从未收到该onClicked
事件。