TKINTER TUTORIAL
Chương trình "Hello, World!" bằng Tkinter trong Python Tìm hiểu cửa sổ Tkinter trong Python Tìm hiểu về các Widget Tkinter trong Python 3 cách đặt Options cho Widget Tkinter trong Python Ràng buộc lệnh trong Tkinter Tìm hiểu Event Binding của Tkinter trong Python Giới thiệu widget Label trong Tkinter Cách sử dụng widget Entry trong Tkinter Trình quản lý hình học Pack trong Tkinter Trình quản lý hình học Grid trong Tkinter Trình quản lý hình học Place trong Tkinter Kích thước Widget trong Tkinter Tìm hiểu về widget Frame trong Tkinter Cách sử dụng widget Text của Tkinter Tìm hiểu về widget Scrollbar của Tkinter Cách sử dụng widget ScrolledText của Tkinter Cách sử dụng widget Separator của Tkinter Cách sử dụng Widget Checkbox Trong Tkinter Cách sử dụng widget radio button của Tkinter Cách tạo widget combobox trong Tkinter Cách sử dụng widget Listbox trong Tkinter Sử dụng widget PanedWindow trong Tkinter Cách tạo widget Spinbox trong Tkinter Hướng dẫn sử dụng Slider trong Tkinter Cách sử dụng widget Sizegrip trong Tkinter Cách sử dụng widget LabelFrame trong Tkinter Cách sử dụng widget Progressbar trong Tkinter Cách sử dụng widget Notebook trong Tkinter Cách sử dụng về widget Treeview trong Tkinter Hướng dẫn về Canvas trong Tkinter Cách thiết lập con trỏ widget trong Tkinter. Window hướng đối tượng trong Tkinter Các Frame hướng đối tượng trong Tkinter Cách sử dụng Object-Oriented Application trong Tkinter Phương thức tkraise() của Frame trong Tkinter Các kiểu (Styles) trong Tkinter Cách thay đổi theme trong Tkinter Các element của ttk trong Tkinter Tìm hiểu về đối tượng Tkinter StringVar trong Tkinter Cách sử dụng phương thức map() của ttk.Style Cách sử dụng phương thức after() của Tkinter Cách sử dụng threads trong Tkinter Cách hiển thị progress bar khi thread đang chạy trong Tkinter. Cách tạo nhiều cửa sổ trong một Tkinter Cách sử dụng widget PhotoImage của Tkinter Cấu trúc MVC trong Tkinter Cách sử dụng Validate trong Tkinter Cách hiển thị đồ thị từ thư viện Matplotlib trong Tkinter Ứng dụng System Tray với Tkinter
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 widget Notebook trong Tkinter

Trong giao diện người dùng (GUI) bằng Python, việc tổ chức và hiển thị thông tin một cách hiệu quả là rất quan trọng. Widget Notebook trong Tkinter cung cấp một giải pháp tiện lợi giúp bạn tạo ra các tab, cho phép người dùng dễ dàng chuyển đổi giữa các trang nội dung khác nhau trong cùng một cửa sổ ứng dụng. Bài viết này sẽ giới thiệu chi tiết cách sử dụng widget Notebook, từ việc tạo các tab cơ bản đến quản lý chúng, giúp bạn xây dựng giao diện người dùng trực quan và thân thiện hơ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ề widget Tkinter Notebook

Widget Notebook cho phép bạn chọn các trang nội dung bằng cách nhấp vào các tab:

Tkinter Notebook Example png

Khi bạn nhấp vào một trong các tab này, widget Notebook sẽ hiển thị một khung con (child pane) liên kết với tab được chọn. Thường thì một khung con là một widget Frame.

Để tạo một widget Notebook, bạn sử dụng lớp ttk.Notebook như sau:

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

notebook = ttk.Notebook(master, **kw)

Trong cú pháp này:

  • master: Là widget cha của Notebook, thường là cửa sổ chính (main window).
  • **kw: Cho phép bạn chỉ định các tham số điều khiển giao diện của widget Notebook.

Widget Notebook có một số tùy chọn hữu ích, chẳng hạn như bạn có thể sử dụng tùy chọn heightwidth để chỉ định không gian cho widget. Ngoài ra, bạn có thể thêm khoảng trống xung quanh bên ngoài của widget bằng tùy chọn padding.

Các phương thức của Notebook

Lớp ttk.Notebook cung cấp nhiều phương thức hữu ích để bạn quản lý các tab một cách hiệu quả.

Dưới đây là mô tả về các phương thức được sử dụng phổ biến nhất:

add(child, **kwargs)

Phương thức add() thêm một widget con vào cửa sổ. Đối số **kwargs là một hoặc nhiều tùy chọn. Dưới đây là các tùy chọn quan trọng:

  • child: Là widget để thêm vào Notebook.
  • text: Xác định nhãn (label) xuất hiện trên tab.
  • image: Xác định hình ảnh hiển thị trên tab.
  • Nếu bạn sử dụng cả textimage, bạn cần sử dụng tùy chọn compound. Tùy chọn này mô tả vị trí của hình ảnh so với văn bản. Nó có thể là tk.TOP, tk.BOTTOM, tk.LEFT, tk.RIGHT, hoặc tk.CENTER. Ví dụ, tk.LEFT sẽ đặt hình ảnh bên trái văn bản.
  • underline: Xác định vị trí của ký tự trong văn bản trên tab sẽ được gạch chân.

hide(tabId)

Phương thức hide() tạm thời loại bỏ tab được xác định bằng tabId khỏi Notebook. Tab có chỉ mục bắt đầu từ 0, nghĩa là tab đầu tiên có chỉ mục là 0.

Để hiển thị lại tab, bạn cần gọi lại phương thức add(). Không có phương thức show() tương ứng.

forget(child)

Phương thức forget() xóa vĩnh viễn widget con được chỉ định khỏi Notebook.

Ví dụ về widget Tkinter Notebook

Chương trình dưới đây sẽ minh họa cách tạo một Notebook với hai tab:

import tkinter as tk
from tkinter import ttk

# Tạo cửa sổ chính
root = tk.Tk()
root.geometry('400x300')
root.title('Notebook Demo')

# Tạo một Notebook
notebook = ttk.Notebook(root)
notebook.pack(pady=10, expand=True)

# Tạo các Frame
frame1 = ttk.Frame(notebook, width=400, height=280)
frame2 = ttk.Frame(notebook, width=400, height=280)

frame1.pack(fill='both', expand=True)
frame2.pack(fill='both', expand=True)

# Thêm các Frame vào Notebook
notebook.add(frame1, text='Thông tin chung')
notebook.add(frame2, text='Hồ sơ')

# Chạy vòng lặp chính
root.mainloop()

Kết quả:

Tkinter Notebook png

Cách hoạt động

Đầu tiên, tạo một widget Notebook mà widget cha của nó là cửa sổ chính (root):

notebook = ttk.Notebook(root)
notebook.pack(pady=10, expand=True)

Tiếp theo, tạo hai Frame mà widget cha của chúng là Notebook:

frame1 = ttk.Frame(notebook, width=400, height=280)
frame2 = ttk.Frame(notebook, width=400, height=280)

frame1.pack(fill='both', expand=True)
frame2.pack(fill='both', expand=True)

Cuối cùng, thêm các Frame này vào Notebook bằng phương thức add():

notebook.add(frame1, text='Thông tin chung')
notebook.add(frame2, text='Hồ sơ')

Kết bài

Qua bài viết này, bạn đã nắm được cách tạo và sử dụng widget Notebook trong Tkinter để tạo các tab giao diện. Bạn đã học cách thêm, ẩn và xoá các tab bằng cách sử dụng các phương thức như add(), hide(), và forget(). Với những kiến thức này, bạn có thể dễ dàng triển khai các giao diện phức tạp hơn, giúp nâng cao trải nghiệm người dùng trong ứng dụng của mình.

Cùng chuyên mục:

Cách tạo một widget nhập ngày và giờ sử dụng PyQt QDateTimeEdit

Cách tạo một widget nhập ngày và giờ sử dụng PyQt QDateTimeEdit

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 giờ sử dụng lớp PyQt QTimeEdit

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 ngày sử dụng lớp PyQt QDateEdit

Cách sử dụng widget PyQt QSpinBox để tạo một spin box

Cách sử dụng widget PyQt QSpinBox để tạo một spin box

Sử dụng PyQt QComboBox để tạo Widget Combobox

Sử dụng PyQt QComboBox để tạo Widget Combobox

Cách sử dụng lớp PyQt QRadioButton

Cách sử dụng lớp PyQt QRadioButton

Cách sử dụng lớp QCheckBox trong PyQt

Cách sử dụng lớp QCheckBox trong PyQt

Cách sử dụng QFormLayout trong PyQt

Cách sử dụng QFormLayout trong PyQt

Cách sử dụng QGridLayout trong PyQt

Cách sử dụng QGridLayout trong PyQt

Cách sử dụng QVBoxLayout trong PyQt

Cách sử dụng QVBoxLayout trong PyQt

Cách sử dụng widget QLineEdit trong PyQt

Cách sử dụng widget QLineEdit trong PyQt

Cách sử dụng widget QPushButton của PyQt

Cách sử dụng widget QPushButton của PyQt

Cách sử dụng widget PyQt QLabel

Cách sử dụng widget PyQt QLabel

Tín hiệu và Khe (Signals & Slots) trong PyQt

Tín hiệu và Khe (Signals & Slots) trong PyQt

PyQt là gì? Tạo một chương trình

PyQt là gì? Tạo một chương trình "Hello World".

Ứng dụng System Tray với Tkinter

Ứng dụng System Tray với Tkinter

Cách hiển thị đồ thị từ thư viện Matplotlib trong Tkinter

Cách hiển thị đồ thị từ thư viện Matplotlib trong Tkinter

Cách sử dụng Validate trong Tkinter

Cách sử dụng Validate trong Tkinter

Cấu trúc MVC trong Tkinter

Cấu trúc MVC trong Tkinter

Cách sử dụng widget PhotoImage của Tkinter

Cách sử dụng widget PhotoImage của Tkinter

Top