QTreeView StandardItem.insertRow(0, new_item) 插入自身而不是 new_item?

QTreeView StandardItem.insertRow(0, new_item) inserts itself instead of new_item?

我想在我的树视图中的子项的第 0 行插入一个新项。 代码看起来很简单,但我想我 运行 遇到了一个错误? 我简化了问题以避免大量不需要的代码。 我做错了什么吗?

需要说明的是,如果我对 StandardItemModel 本身调用 insertRow() ……它确实有效。 但是我需要它来处理模型的子项。

QT 版本:6.0.0 PySide 版本:6.0.0 OS: Ubuntu 20.10 (KDE)

class MyTreeView(QTreeView):
    def __init__(self, parent):
        super().__init__(parent)
        model = MyModel()
        self.setModel(model)
    
class MyModel(QStandardItemModel):
    def __init__(self):
        super().__init__()
        self.root_item = self.invisibleRootItem()
        self.top_level = QStandardItem("Top level")
        self.root_item.appendRow(self.top_level)

        self.top_level.appendRow(QStandardItem('Appended item'))
        self.top_level.insertRow(0, QStandardItem('Inserted item'))

现在我希望得到这样的结果:

    - Top level
      - Inserted item
      - Appended item

然而我得到的结果是:

    - Top level
      - Top level
      - Appended item

当你直接insertRow() 一个项目时,它似乎会超出范围。 此示例的解决方案是先将其分配给 self。

我仍然认为这是一个错误,因为 appendRow() 确实模仿了这种行为。

class MyTreeView(QTreeView):
    def __init__(self, parent):
        super().__init__(parent)
        model = MyModel()
        self.setModel(model)
    
class MyModel(QStandardItemModel):
    def __init__(self):
        super().__init__()
        self.root_item = self.invisibleRootItem()
        self.top_level = QStandardItem("Top level")
        self.root_item.appendRow(self.top_level)

        self.top_level.appendRow(QStandardItem('Appended item'))
        # CHANGE START
        self.insert_item = QStandardItem('Inserted item')
        self.top_level.insertRow(0, self.insert_item)
        # CHANGE END