我有不同的容器物品,当他们的所有孩子都不可见时,我想让它们不可见。
动态地,一些代码递归地解析所有项目并根据某些过滤器(如搜索输入)将它们设置为可见或不可见。此过滤将忽略容器项。
过滤后,如何检测可见性已更改并相应地更新我的容器项目?
到目前为止,我有这段代码,但每次更改孩子的可见性时我都需要执行此代码:
visible: visibleChildren.size > 0
我有不同的容器物品,当他们的所有孩子都不可见时,我想让它们不可见。
动态地,一些代码递归地解析所有项目并根据某些过滤器(如搜索输入)将它们设置为可见或不可见。此过滤将忽略容器项。
过滤后,如何检测可见性已更改并相应地更新我的容器项目?
到目前为止,我有这段代码,但每次更改孩子的可见性时我都需要执行此代码:
visible: visibleChildren.size > 0
试试这个:
visible: visibleChildren.length > 0
事实上,也只visible: visibleChildren.length
会这样做。
visibleChildren.size
是undefined
- 没有size
成员。
请记住,根据以下代码的行为判断,将项目设置回可见时会出现问题:
MouseArea {
anchors.fill: parent
onClicked: inner.visible = !inner.visible
}
Rectangle {
id: outer
anchors.fill: parent
color: "blue"
visible: visibleChildren.length
Rectangle {
id: inner
width: 50
height: 50
color: "red"
}
}
一旦父项变为不可见,内部项的可见性始终为假,即使明确设置为真。
发生的情况是,如果其父级不可见,则无法将子级设置为可见,因此一旦visibleChildren
为空,就无法通过将子级设置为可见来填充它。当父项不可见时,子项不能设置为可见,如果没有可见子项,则父项是不可见的。
因此,如果这种行为是您的要求,您将不得不实现一些其他可见性跟踪机制,而不是使用visibleChildren
.