PYQT TUTORIAL
PyQt là gì? Tạo một chương trình "Hello World". Tín hiệu và Khe (Signals & Slots) trong PyQt Cách sử dụng widget PyQt QLabel Cách sử dụng widget QPushButton của PyQt Cách sử dụng widget QLineEdit trong PyQt Cách sử dụng QVBoxLayout trong PyQt Cách sử dụng QGridLayout trong PyQt Cách sử dụng QFormLayout trong PyQt Cách sử dụng lớp QCheckBox trong PyQt Cách sử dụng lớp PyQt QRadioButton Sử dụng PyQt QComboBox để tạo Widget Combobox Cách sử dụng widget PyQt QSpinBox để tạo một spin box Cách tạo một widget nhập ngày sử dụng lớp PyQt QDateEdit Cách tạo một widget nhập giờ sử dụng lớp PyQt QTimeEdit Cách tạo một widget nhập ngày và giờ sử dụng PyQt QDateTimeEdit Cách sử dụng lớp PyQt QSlider để tạo một widget thanh trượt (slider). Cách dùng PyQt QWidget để làm container chứa các widget khác. Cách dùng lớp PyQt QTabWidget để tạo một widget dạng tab Cách dùng lớp PyQt QGroupBox để tạo một khung nhóm với tiêu đề Cách dùng lớp PyQt QTextEdit để tạo một widget cho phép chỉnh sửa Cách sử dụng lớp PyQt QProgressBar để tạo một widget progress bar Cách sử dụng lớp PyQt QMessageBox để tạo một hộp thoại Cách dùng lớp PyQt QInputDialog để tạo một hộp thoại nhập liệu Cách dùng lớp PyQt QFileDialog để tạo hộp thoại chọn file Cách sử dụng lớp QMainWindow của PyQt để tạo cửa sổ Cách sử dụng lớp PyQt QMenu để tạo menu Cách dùng lớp PyQt QToolBar để tạo các widget toolbar Cách dùng lớp QDockWidget của PyQt để tạo một widget Cách dùng lớp QStatusBar trong PyQt để tạo thanh status bar Cách sử dụng lớp QListWidget trong Python Cách sử dụng lớp QTableWidget để tạo một bảng Cách sử dụng lớp QTreeWidget của PyQt Cách sử dụng Qt Designer để thiết kế UX/UI trong PyQt. Cách sử dụng QThread trong PyQt Cách tạo các lớp QThreadPool đa luồng trong PyQt Cách hoạt động của Model/View trong PyQt Cách sử dụng Qt Style Sheets (QSS) trong PyQt.
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Thông báo: Download 4 khóa học Python từ cơ bản đến nâng cao tại đây.

Cách sử dụng QFormLayout trong PyQt

Trong bài viết này, bạn sẽ tìm cách sử dụng PyQt QFormLayout để sắp xếp các widget trong một biểu mẫu nhập liệu một cách gọn gàng và có tổ chức. QFormLayout là một công cụ mạnh mẽ, giúp bạn dễ dàng tạo các biểu mẫu có cấu trúc rõ ràng với các nhãn và trường đầu vào được sắp xếp hợp lý, mang lại trải nghiệm người dùng tốt hơn trong các ứng dụng của bạn.

test php

banquyen png
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Giới thiệu về PyQt QFormLayout

Khi tạo biểu mẫu nhập liệu, bạn thường cần đặt các trường dữ liệu theo hàng. Trên mỗi hàng, bạn sẽ đặt một nhãn (label) cạnh một widget đầu vào.

PyQt cung cấp cho bạn một bố cục biểu mẫu tiện lợi với hai cột, sắp xếp các widget trên biểu mẫu. Cột bên trái chứa nhãn và cột bên phải chứa widget đầu vào.

Để tạo bố cục biểu mẫu, bạn sử dụng lớp QFormLayout:

Bài viết này được đăng tại [free tuts .net]

layout = QFormLayout(self)
self.setLayout(layout) # self là widget cha

Việc thêm các widget vào bố cục biểu mẫu có thể được thực hiện bằng phương thức addRow(). Ví dụ:

layout.addRow('Trường 1', input_widget1)
layout.addRow('Trường 2', input_widget2)

Phương thức addRow() nhận một chuỗi và một widget, và tự động tạo ra widget QLabel cho chuỗi đó.

Nếu bạn truyền một widget đơn lẻ như QLabel, widget này sẽ tự động trải dài cả hai cột. Trên thực tế, bạn có thể sử dụng tính năng này để tạo tiêu đề hoặc nhãn cho các phần trong biểu mẫu.

Ngoài việc cung cấp sự tiện lợi, QFormLayout tuân thủ các hướng dẫn về giao diện và cảm nhận của nền tảng. Ví dụ, khi sử dụng trên macOS, các nhãn sẽ căn phải, trong khi trên Windows, các nhãn sẽ căn trái.

Hơn nữa, khi hiển thị trên màn hình hẹp, bố cục sẽ tự động thu gọn thành một cột với các nhãn nằm trên các widget đầu vào.

Ví dụ về PyQt QFormLayout

Ví dụ sau đây minh họa cách tạo một biểu mẫu đăng ký sử dụng QFormLayout:

import sys
from PyQt6.QtWidgets import QApplication, QWidget, QPushButton, QLineEdit, QFormLayout

class MainWindow(QWidget):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)

        self.setWindowTitle('Biểu Mẫu Đăng Ký')

        layout = QFormLayout()
        self.setLayout(layout)

        layout.addRow('Tên:', QLineEdit(self))
        layout.addRow('Email:', QLineEdit(self))
        layout.addRow('Mật Khẩu:', QLineEdit(self, echoMode=QLineEdit.EchoMode.Password))
        layout.addRow('Xác Nhận Mật Khẩu:', QLineEdit(self, echoMode=QLineEdit.EchoMode.Password))
        layout.addRow('Số Điện Thoại:', QLineEdit(self))

        layout.addRow(QPushButton('Đăng Ký'))

        # Hiển thị cửa sổ
        self.show()

if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MainWindow()
    sys.exit(app.exec())

Kết quả:

PyQt QFormLayout png

Kết bài

Hãy tận dụng QFormLayout trong PyQt để xây dựng các biểu mẫu nhập liệu một cách nhanh chóng và hiệu quả, từ đó cải thiện đáng kể trải nghiệm người dùng trong ứng dụng của bạn. Với QFormLayout, việc sắp xếp các trường thông tin trở nên đơn giản và trực quan, giúp bạn tập trung hơn vào việc phát triển các tính năng quan trọng khác của ứng dụng.

Cùng chuyên mục:

Cách sử dụng Qt Style Sheets (QSS) trong PyQt.

Cách sử dụng Qt Style Sheets (QSS) trong PyQt.

Cách hoạt động của Model/View trong PyQt

Cách hoạt động của Model/View trong PyQt

Cách tạo các lớp QThreadPool đa luồng trong PyQt

Cách tạo các lớp QThreadPool đa luồng trong PyQt

Cách sử dụng QThread trong PyQt

Cách sử dụng QThread trong PyQt

Cách sử dụng Qt Designer để thiết kế UX/UI trong PyQt.

Cách sử dụng Qt Designer để thiết kế UX/UI trong PyQt.

Cách sử dụng lớp QTreeWidget của PyQt

Cách sử dụng lớp QTreeWidget của PyQt

Cách sử dụng lớp QTableWidget để tạo một bảng

Cách sử dụng lớp QTableWidget để tạo một bảng

Cách sử dụng lớp QListWidget trong Python

Cách sử dụng lớp QListWidget trong Python

Cách dùng lớp QStatusBar trong PyQt để tạo thanh status bar

Cách dùng lớp QStatusBar trong PyQt để tạo thanh status bar

Cách dùng lớp QDockWidget của PyQt để tạo một widget

Cách dùng lớp QDockWidget của PyQt để tạo một widget

Cách dùng lớp PyQt QToolBar để tạo các widget toolbar

Cách dùng lớp PyQt QToolBar để tạo các widget toolbar

Cách sử dụng lớp PyQt QMenu để tạo menu

Cách sử dụng lớp PyQt QMenu để tạo menu

Cách sử dụng lớp QMainWindow của PyQt để tạo cửa sổ

Cách sử dụng lớp QMainWindow của PyQt để tạo cửa sổ

Cách dùng lớp PyQt QFileDialog để tạo hộp thoại chọn file

Cách dùng lớp PyQt QFileDialog để tạo hộp thoại chọn file

Cách dùng lớp PyQt QInputDialog để tạo một hộp thoại nhập liệu

Cách dùng lớp PyQt QInputDialog để tạo một hộp thoại nhập liệu

Cách sử dụng lớp PyQt QMessageBox để tạo một hộp thoại

Cách sử dụng lớp PyQt QMessageBox để tạo một hộp thoại

Cách sử dụng lớp PyQt QProgressBar để tạo một widget progress bar

Cách sử dụng lớp PyQt QProgressBar để tạo một widget progress bar

Cách dùng lớp PyQt QTextEdit để tạo một widget cho phép chỉnh sửa

Cách dùng lớp PyQt QTextEdit để tạo một widget cho phép chỉnh sửa

Cách dùng lớp PyQt QGroupBox để tạo một khung nhóm với tiêu đề

Cách dùng lớp PyQt QGroupBox để tạo một khung nhóm với tiêu đề

Cách dùng lớp PyQt QTabWidget để tạo một widget dạng tab

Cách dùng lớp PyQt QTabWidget để tạo một widget dạng tab

Top