如何在 tk.Frame 中正确嵌入 ttk.Notebook 组件
发布时间 - 2026-01-20 00:00:00 点击率:次本文详解如何将 `ttk.notebook` 成功添加到 `tk.frame` 中,涵盖创建、布局、标签页添加及关键注意事项,附可运行代码示例。
在 Tkinter 中,ttk.Notebook 是一个容器型控件,用于实现多标签页界面。它本身不直接“显示内容”,而是作为标签页的管理器——你需要先创建 Notebook 实例,再通过 pack/grid/place 将其布局到父容器(如 tk.Frame)中,最后向其添加子 Frame 作为各个标签页的内容区域。
关键点在于:仅实例化 ttk.Notebook(self.frame0) 并不够;必须显式调用布局方法(如 .grid() 或 .pack()),否则组件不会渲染。
以下是在你原有 MyApp 类中集成 Notebook 的完整修正示例(基于 grid 布局,兼顾灵活性与可扩展性):
import tkinter as tk
from tkinter import ttk
class MyApp(tk.Tk):
def __init__(self):
super().__init__()
self.title("hello world")
# 创建两个主 Frame
self.frame0 = tk.Frame(self, background="green")
self.frame1 = tk.Frame(self, background="blue")
self.frame0.pack(side="top", fill="both", expand=True)
self.frame1.pack(side="top", fill=tk.X, expand=True)
# 在 frame0 中创建并布局 Notebook
self.tabControl = ttk.Notebook(self.frame0)
self.tabControl.grid(row=0, column=0, sticky="nsew", padx=2, pady=2)
# 配置 grid 权重,确保 
Notebook 可随窗口缩放
self.frame0.grid_rowconfigure(0, weight=1)
self.frame0.grid_columnconfigure(0, weight=1)
# 创建标签页内容 Frame
self.tab1 = tk.Frame(self.tabControl, background="#f0f0f0")
self.tab2 = tk.Frame(self.tabControl, background="#e0e0e0")
# 添加标签页(注意:顺序决定默认选中项)
self.tabControl.add(self.tab1, text="Tab 0")
self.tabControl.add(self.tab2, text="Tab 1")
# 在各标签页中添加示例内容
tk.Label(self.tab1, text="Content of Tab 0", font=("Arial", 10)).pack(pady=20)
tk.Label(self.tab2, text="Content of Tab 1", font=("Arial", 10)).pack(pady=20)
# frame1 中保留原 "OTHER" 标签
self.frame1_label0 = tk.Label(self.frame1, text="OTHER", font=("Arial", 12))
self.frame1_label0.grid(row=0, column=0, padx=10, pady=5)
def main():
app = MyApp()
app.minsize(480, 320) # 设置最小尺寸,避免 Notebook 被压缩不可见
app.mainloop()
if __name__ == "__main__":
main()? 重要注意事项:
- ✅ 必须布局:ttk.Notebook 实例创建后,务必调用 .grid() / .pack() / .place(),否则不可见;
- ✅ 权重配置:若使用 grid,需为父 Frame 设置 rowconfigure 和 columnconfigure 的 weight=1,否则 Notebook 不会随窗口拉伸;
- ✅ 子 Frame 必须归属 Notebook:每个 tab 的内容 Frame 应以 self.tabControl 为父容器(而非 self.frame0),否则无法被 Notebook 管理;
- ⚠️ 避免混用布局管理器:同一父容器内不要同时对子组件使用 pack() 和 grid(),否则会引发 TclError;
- ? 提示:可通过 self.tabControl.select(tab_index) 或 self.tabControl.select(tab_id) 编程切换当前页。
通过以上方式,你即可在任意 tk.Frame 中灵活嵌入功能完备的多标签界面,为复杂 GUI 构建打下坚实基础。
# app
# ai
# select
# 管理器
# 为父
# 是一个
# 是在
# 将其
# 而非
# 可通过
# 则会
# 应以
# 如何将
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何在阿里云虚拟主机上快速搭建个人网站?
如何用狗爹虚拟主机快速搭建网站?
5种Android数据存储方式汇总
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
iOS中将个别页面强制横屏其他页面竖屏
详解阿里云nginx服务器多站点的配置
个人网站制作流程图片大全,个人网站如何注销?
奇安信“盘古石”团队突破 iOS 26.1 提权
ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】
Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作
Laravel怎么判断请求类型_Laravel Request isMethod用法
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
如何快速打造个性化非模板自助建站?
Firefox Developer Edition开发者版本入口
深圳网站制作培训,深圳哪些招聘网站比较好?
ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法
Python自动化办公教程_ExcelWordPDF批量处理案例
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
如何在阿里云购买域名并搭建网站?
今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】
桂林网站制作公司有哪些,桂林马拉松怎么报名?
Laravel如何配置任务调度?(Cron Job示例)
,南京靠谱的征婚网站?
电商网站制作价格怎么算,网上拍卖流程以及规则?
Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
如何为不同团队 ID 动态生成多个独立按钮
如何注册花生壳免费域名并搭建个人网站?
java中使用zxing批量生成二维码立牌
Laravel如何使用Blade模板引擎?(完整语法和示例)
Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
微信小程序 wx.uploadFile无法上传解决办法
简历在线制作网站免费版,如何创建个人简历?
如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程
佛山网站制作系统,佛山企业变更地址网上办理步骤?
php 三元运算符实例详细介绍
iOS发送验证码倒计时应用
大型企业网站制作流程,做网站需要注册公司吗?
Python并发异常传播_错误处理解析【教程】
Laravel如何处理CORS跨域请求?(配置示例)
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用
linux写shell需要注意的问题(必看)
如何在云指建站中生成FTP站点?
Android Socket接口实现即时通讯实例代码
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
如何在景安服务器上快速搭建个人网站?


