PyQt5高级界面控件之QLIstView(二)
前言
QlistView类用于展示数据,它的子类是QListWIdget。QListView是基于模型(Model)的,需要程序来建立模型,然后再保存数据
QListWidget是一个升级版本的QListView,它已经建立了一个数据储存模型(QListWidgetItem),直接调用addItem()函数,就可以添加条目(Item)
QListView类中常用的方法如表
方法 | 描述 |
---|---|
setModel() | 用来设置View所关联的Model,可以使用Python原生的list作为数据源Model |
selectedItem() | 选中Model的条目 |
isSelected() | 判断Model中的某条目是否被选中 |
QListView的常用信号
信号 | 含义 |
---|---|
clicked | 当单击某项时,信号被发射 |
doubleClicked | 当双击某项时,信号被发射 |
实例:QListView的使用
import sys
from PyQt5.QtWidgets import QApplication,QWidget,QVBoxLayout,QListView,QMessageBox
from PyQt5.QtCore import QStringListModel
class ListViewDemo(QWidget):
def __init__(self,parent=None):
super(ListViewDemo, self).__init__(parent)
#设置初始大小与标题
self.resize(300,270)
self.setWindowTitle('QListView 例子')
#垂直布局
layout=QVBoxLayout()
#实例化列表视图
listview=QListView()
#实例化列表模型,添加数据
slm=QStringListModel()
self.qList=['Item 1','Item 2','Item 3','Item 4']
#设置模型列表视图,加载数据列表
slm.setStringList(self.qList)
#设置列表视图的模型
listview.setModel(slm)
#单击触发自定义的槽函数
listview.clicked.connect(self.clicked)
#设置窗口布局,加载控件
layout.addWidget(listview)
self.setLayout(layout)
def clicked(self,qModelIndex):
#提示信息弹窗,你选择的信息
QMessageBox.information(self,'ListWidget','你选择了:'+self.qList[qModelIndex.row()])
if __name__ == '__main__':
app=QApplication(sys.argv)
win=ListViewDemo()
win.show()
sys.exit(app.exec_())
效果如图
在这个例子中,当单击QListView控件中的Model中的一项时会弹出消息框(提示选中的是哪一项)
将QListView控件的clicked信号与自定义对象的clicked()槽函数进行绑定
listview.clicked.connect(self.clicked)
def clicked(self,qModelIndex):
#提示信息弹窗,你选择的信息
QMessageBox.information(self,'ListWidget','你选择了:'+self.qList[qModelIndex.row()])
QListView
- 前言
- QListView类中常用的方法如表
- QListView的常用信号
实例:QListView的使用
- 相关文件及下载地址
相关文件及下载地址
https://download.csdn.net/download/jia666666/10609488
还没有评论,来说两句吧...