0

当用户点击 QML 窗口中的按钮时,是否可以显示 QML 对话框?

示例

当用户单击菜单栏中的帮助 -> 关于时,应显示关于对话框:

import QtQuick 2.12
import QtQuick.Layouts 1.12
import QtQuick.Window 2.12
import QtQuick.Controls 2.12

import "components"

ApplicationWindow {
    id: window
    visible: true
    width: 1040
    height: 480


    aboutDlg: aboutDialog {}  // does not work...

    menuBar: MenuBar {
        Menu {
            title: qsTr("Help")
            MenuItem {
                text: qsTr("About")
                onTriggered: aboutDlg.open();
        }
    }
    ...

组件/AboutDialog.qml

import QtQuick 2.2
import QtQuick.Dialogs 1.1

MessageDialog {
    id: aboutDialog
    title: "May I have your attention please"
    text: "It's so cool that you are using Qt Quick."
    onAccepted: {
        console.log("And of course you could only agree.")
        Qt.quit()
    }
}

当我删除该行时boutDlg: aboutDialog {} // does not work...,单击“关于”菜单项时报告以下错误:

qrc:/main.qml:61: ReferenceError: aboutDlg 未定义

我怎样才能做到这一点?

4

1 回答 1

1

您调用了“aboutDialog”,它是 AboutDialog 中的一个 ID。把它想象成你添加一个对象,就像添加一个矩形......它有自己的文件......你可以通过添加这样的对象来“实例化”它:

...

ApplicationWindow {

...

    AboutDialog {
        id: aboutDlg
    }

...
}

你可以在这里找到例子

您还可以进行一些优化并将 AboutDialog 放在Loader中。

于 2019-04-23T15:47:33.583 回答