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
我想在我的树视图中的子项的第 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