通過點擊左邊的列表選項, 通過綁定按鈕,使得右側的堆棧窗口控件的界面顯示發生變化
QStackedWidget.py
""" 堆棧窗口控件(QStackedWidget) """ import sys from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import * class StackedExample(QWidget): def __init__(self): super(StackedExample, self).__init__() self.setGeometry(300, 50, 10, 10) self.setWindowTitle("堆棧窗口控件 (QStackedWidget)") self.list = QListWidget() self.list.insertItem(0, "聯系方式") self.list.insertItem(1, "個人信息") self.list.insertItem(2, "教育程度") self.stack1 = QWidget() self.stack2 = QWidget() self.stack3 = QWidget() self.tab1UI() self.tab2UI() self.tab3UI() #構造堆棧窗口 self.stack = QStackedWidget() #將界面添加到窗口上 self.stack.addWidget(self.stack1) self.stack.addWidget(self.stack2) self.stack.addWidget(self.stack3) hbox = QHBoxLayout() hbox.addWidget(self.list) hbox.addWidget(self.stack) self.setLayout(hbox) #對於列表進行點擊綁定 self.list.currentRowChanged.connect(self.display) def tab1UI(self): layout = QFormLayout() layout.addRow("姓名", QLineEdit()) layout.addRow("地址", QLineEdit()) # 在界面上添加對應的控件 self.stack1.setLayout(layout) def tab2UI(self): layout = QFormLayout() sex = QHBoxLayout() sex.addWidget(QRadioButton("男")) sex.addWidget(QRadioButton("女")) layout.addRow(QLabel('性別'), sex) layout.addRow("生日", QLineEdit()) self.stack2.setLayout(layout) def tab3UI(self): layout = QHBoxLayout() layout.addWidget(QLabel("科目")) layout.addWidget(QCheckBox("物理")) layout.addWidget(QCheckBox("高數")) self.stack3.setLayout(layout) def display(self, index): #設置當前的堆棧界面顯示為第幾個界面 self.stack.setCurrentIndex(index) if __name__ == "__main__": app = QApplication(sys.argv) main = StackedExample() main.show() sys.exit(app.exec_())