如何将s信号从一个qml组件发送到另一个qml组件?
以下是一个例子:
Rectangle {
id: main
width: 360; height: 360
signal clicked()
Text {
id: testStr
anchors.centerIn: parent
text: "Hello World"
}
MouseArea {
id: mouseArea
anchors.fill: parent
onClicked: { Qt.quit(); }
}
Component.onCompleted: clicked()
onClicked: testStr.text = "Demo"
}
如何捕获其他组件中的信号?
答案 0 :(得分:13)
您应该使用组件信号的connect()
方法(信号本身就是对象)。
function clickHandler() {
console.log('main clicked')
}
Component.onCompleted: {
main.clicked.connect(clickHandler)
}
答案 1 :(得分:9)
在另一个对象中,您只需添加一个on
字,后跟信号名称。 EG:
Rectangle {
YourQmlObject {
onClicked: { ... }
}
}
(点击有点令人困惑的信号名称因为它很常见。但是如果你调用了你的信号orange
,你就会进行绑定onOrange:
)
答案 2 :(得分:5)
您可以使用QML连接元素
Connections {
target: yourQmlObject
onClicked: foo(...)
}
答案 3 :(得分:0)
QML
Button{
id: btn_add_pq
text: "Add"
onClicked: {
var component = Qt.createComponent("add_pq.qml")
var dialog = component.createObject(root)
dialog.open()
dialog.accepted.connect(function(){
console.log("ID :" + window.in_id)
console.log("Name :" + window.in_name)
console.log("Comment:" + window.in_comment)
})
}
}
add_pq.qml
Dialog {
id:dialog
...
property alias in_id: txtID.text
property alias in_comment: txtComment.text
property alias in_name: txtName.text
...
contentItem: GridLayout{
...
TextField{
id: txtComment
Layout.alignment: Qt.AlignRight
}
Button{
Layout.columnSpan: 2
text: "Add"
Layout.alignment: Qt.AlignRight
onClicked: {
dialog.click(StandardButton.Save)
}
}
}