1

我有不同的容器物品,当他们的所有孩子都不可见时,我想让它们不可见。

动态地,一些代码递归地解析所有项目并根据某些过滤器(如搜索输入)将它们设置为可见或不可见。此过滤将忽略容器项。

过滤后,如何检测可见性已更改并相应地更新我的容器项目?

到目前为止,我有这段代码,但每次更改孩子的可见性时我都需要执行此代码:

visible: visibleChildren.size > 0
4

1 回答 1

3

试试这个:

visible: visibleChildren.length > 0

事实上,也只visible: visibleChildren.length会这样做。

visibleChildren.sizeundefined- 没有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.

于 2018-02-08T11:01:42.637 回答