小白之Tkinter库读文:基础组件-Menu 菜单(14)
zhezhongyun 2025-05-09 22:49 23 浏览
1.13 Menu 菜单
说明
Menu 是 Tkinter 中用于创建菜单的组件。菜单可以包含命令项、子菜单、分隔符等,通常用于实现应用程序的菜单栏、上下文菜单等功能。
创建
menu = tk.Menu(root)
- 作用:创建一个菜单对象。
- 参数:
- root:父容器(通常是根窗口或其他容器)。
常用方法
以下是 Menu 的常用方法:
add_command(options)
- 说明:添加一个菜单命令项。
- 常用选项:
- label:菜单项显示的文本。
- command:点击菜单项时触发的函数或方法。
- accelerator:设置快捷键(显示在菜单项右侧)。
- state:设置菜单项的状态(如 "normal", "disabled")。
- 示例:
menu.add_command(label="打开", command=open_file)
add_cascade(options)
- 说明:添加一个子菜单。
- 常用选项:
- label:子菜单显示的文本。
- menu:子菜单对象。
- 示例:
submenu = tk.Menu(menu, tearoff=0)
submenu.add_command(label="新建", command=new_file)
menu.add_cascade(label="文件", menu=submenu)
add_separator()
- 说明:添加一个分隔符。
- 示例:
menu.add_separator()
add_radiobutton(options)
- 说明:添加一个单选按钮菜单项。
- 常用选项:
- label:菜单项显示的文本。
- variable:绑定一个变量(如 IntVar 或 StringVar),用于存储选中的值。
- value:该菜单项被选中时,绑定的变量的值。
- command:点击菜单项时触发的函数或方法。
- 示例:
var = tk.IntVar()
menu.add_radiobutton(label="选项 1", variable=var, value=1, command=on_select)
add_checkbutton(options)
- 说明:添加一个复选框菜单项。
- 常用选项:
- label:菜单项显示的文本。
- variable:绑定一个变量(如 IntVar 或 BooleanVar),用于存储复选框的状态。
- command:点击菜单项时触发的函数或方法。
- 示例:
var = tk.BooleanVar()
menu.add_checkbutton(label="显示工具栏", variable=var, command=toggle_toolbar)
delete(start, end)
- 说明:删除指定范围内的菜单项。
- 示例:
menu.delete(0, "end") # 删除所有菜单项
entryconfig(index, options)
- 说明:修改指定菜单项的属性。
- 示例:
menu.entryconfig(0, state="disabled") # 禁用第一个菜单项
示例演示
以下是一个完整的示例,展示如何使用 Menu 创建菜单栏和上下文菜单:
import tkinter as tk
# 创建根窗口
root = tk.Tk()
root.title("Menu 示例")
root.geometry("400x300")
# 定义菜单命令的回调函数
def new_file():
print("新建文件")
def open_file():
print("打开文件")
def save_file():
print("保存文件")
def cut():
print("剪切")
def copy():
print("复制")
def paste():
print("粘贴")
def about():
print("关于")
# 创建菜单栏
menubar = tk.Menu(root)
# 创建文件菜单
filemenu = tk.Menu(menubar, tearoff=0)
filemenu.add_command(label="新建", command=new_file, accelerator="Ctrl+N")
filemenu.add_command(label="打开", command=open_file, accelerator="Ctrl+O")
filemenu.add_command(label="保存", command=save_file, accelerator="Ctrl+S")
filemenu.add_separator()
filemenu.add_command(label="退出", command=root.quit)
menubar.add_cascade(label="文件", menu=filemenu)
# 创建编辑菜单
editmenu = tk.Menu(menubar, tearoff=0)
editmenu.add_command(label="剪切", command=cut, accelerator="Ctrl+X")
editmenu.add_command(label="复制", command=copy, accelerator="Ctrl+C")
editmenu.add_command(label="粘贴", command=paste, accelerator="Ctrl+V")
menubar.add_cascade(label="编辑", menu=editmenu)
# 创建帮助菜单
helpmenu = tk.Menu(menubar, tearoff=0)
helpmenu.add_command(label="关于", command=about)
menubar.add_cascade(label="帮助", menu=helpmenu)
# 配置根窗口的菜单栏
root.config(menu=menubar)
# 创建上下文菜单
contextmenu = tk.Menu(root, tearoff=0)
contextmenu.add_command(label="剪切", command=cut)
contextmenu.add_command(label="复制", command=copy)
contextmenu.add_command(label="粘贴", command=paste)
# 定义显示上下文菜单的函数
def show_contextmenu(event):
contextmenu.post(event.x_root, event.y_root)
# 绑定右键点击事件
root.bind("<Button-3>", show_contextmenu)
# 启动主循环
root.mainloop()
代码说明
菜单栏:
- 包含“文件”、“编辑”和“帮助”三个菜单。
- “文件”菜单包含“新建”、“打开”、“保存”和“退出”命令。
- “编辑”菜单包含“剪切”、“复制”和“粘贴”命令。
- “帮助”菜单包含“关于”命令。
上下文菜单:
- 右键点击窗口时显示。
- 包含“剪切”、“复制”和“粘贴”命令。
快捷键:
- 使用 accelerator 选项设置快捷键(仅显示,需手动绑定事件)。
事件绑定:
- 使用 bind() 方法绑定右键点击事件,显示上下文菜单。
运行效果
- 窗口大小为 400x300。
- 菜单栏显示在窗口顶部。
- 右键点击窗口时,显示上下文菜单。
- 点击菜单项时,控制台会输出相应的操作。
注意事项
- 使用 tearoff=0 可以禁用菜单的分离功能。
- 快捷键需要通过 bind() 方法手动实现。
通过这个示例,你可以掌握 Menu 的基本用法,并根据需要创建菜单栏和上下文菜单。
相关推荐
- Chinese vice premier calls for multilateralism at Davos
-
DAVOS,Switzerland,Jan.21(Xinhua)--ChineseVicePremierDingXuexiangdeliveredaspeechatthe...
- 用C++ Qt手把手打造炫酷汽车仪表盘
-
一、项目背景与核心价值在车载HMI(人机交互界面)开发领域,虚拟仪表盘是智能座舱的核心组件。本项目基于C++Qt框架实现一个具备专业级效果的时速表模块,涵盖以下技术要点:Qt图形绘制核心机制(QPa...
- 系列专栏(八):JS的第七种基本类型Symbols
-
ES6作为新一代JavaScript标准,已正式与广大前端开发者见面。为了让大家对ES6的诸多新特性有更深入的了解,MozillaWeb开发者博客推出了《ES6InDepth》系列文章。CSDN...
- MFC界面开发工具BCG v31.1 - 增强功能区、工具箱功能
-
点击“了解更多”获取工具亲爱的BCGSoft用户,我们非常高兴地宣布BCGControlBarProfessionalforMFC和BCGSuiteforMFCv31.2正式发布!新版本支...
- 雅居乐上调出售吉隆坡项目保留金,预计亏损扩大至6.64亿元
-
1月2日,雅居乐集团(03383.HK)发布有关出售一家附属公司股权披露交易的补充公告。此前雅居乐集团曾公告,2023年11月8日(交易时段后),集团子公司AgileRealEstateDeve...
- Full text: Address by Vice Premier Ding Xuexiang's at World Economic Forum Annual Meeting 2025
-
DAVOS,Switzerland,Jan.21(Xinhua)--ChineseVicePremierDingXuexiangonTuesdaydeliveredasp...
- 手机性能好不好 GPU玄学曲线告诉你
-
前言各位在看测试者对手机进行评测时或许会见过“安卓玄学曲线”,所谓中的安卓玄学曲线真名为“ProfileGPURendering”。大多数情况下,在系统“开发者选项中被称为“GPU显示配置文件”或...
- 小迈科技 X Hologres:高可用的百亿级广告实时数仓建设
-
通过本文,我们将会介绍小迈科技如何通过Hologres搭建高可用的实时数仓。一、业务介绍小迈科技成立于2015年1月,是一家致力以数字化领先为优势,实现业务高质量自增长的移动互联网科技公司。始...
- vue3新特征和所有的属性,方法汇总及其对应源码分析
-
vue3新特征汇总与源码分析(备注:vue3使用typescript编写)何为应用?constapp=Vue.createApp({})app就是一个应用。应用的配置和应用的API就是app应用...
- China's stability redefines global trade in a volatile era
-
ContainersareunloadedatQingdaoPort,eastChina'sShandongProvince,December10,2024.[Photo/X...
- QML 实现图片帧渐隐渐显轮播
-
前言所谓图片帧渐隐渐显轮播就是,一组图片列表,当前图片逐渐改变透明度隐藏,同时下一张图片逐渐改变透明度显示,依次循环,达到渐隐渐显的效果,该效果常用于图片展示,相比左右自动切换的轮播方式来说,这种方式...
- 前端惊魂夜:我竟在CSS里写出了JavaScript?
-
凌晨两点,写字楼里只剩下我工位上的一盏孤灯。咖啡杯见底,屏幕的光映在疲惫的眼镜片上。为了实现一个极其复杂的动态渐变效果,我翻遍了MDN文档,试遍了所有已知的CSS技巧,却始终差那么一口气。“要是CSS...
- 10 个派上用场的 Flutter 小部件
-
尝试学习一门新语言可能会令人恐惧和厌烦。很多时候,我们希望我们知道早先存在的某些功能。在今天的文章中,我将告诉你我希望早点知道的最方便的颤振小部件。SpacerSpacer创建一个可调整的空白空...
- 让我的 Flutter 代码整洁 10 倍的 5 种
-
如果你曾在Flutter中使用过SingleTickerProviderStateMixin来制作动画,猜猜怎么着?你已经使用过Mixin了——恭喜你,你已经处于一段你甚至不知道的关...
- daisyUI - 主题漂亮、代码纯净!免费开源的 Tailwind CSS 组件库
-
漂亮有特色的CSS组件库,组件代码非常简洁,也支持深度定制主题、定制组件,可以搭配Vue/React等框架使用。关于daisyUIdaisyUI是一款极为流行的CSSUI组件库,...
- 一周热门
- 最近发表
-
- Chinese vice premier calls for multilateralism at Davos
- 用C++ Qt手把手打造炫酷汽车仪表盘
- 系列专栏(八):JS的第七种基本类型Symbols
- MFC界面开发工具BCG v31.1 - 增强功能区、工具箱功能
- 雅居乐上调出售吉隆坡项目保留金,预计亏损扩大至6.64亿元
- Full text: Address by Vice Premier Ding Xuexiang's at World Economic Forum Annual Meeting 2025
- 手机性能好不好 GPU玄学曲线告诉你
- 小迈科技 X Hologres:高可用的百亿级广告实时数仓建设
- vue3新特征和所有的属性,方法汇总及其对应源码分析
- China's stability redefines global trade in a volatile era
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- HTML button formtarget 属性 (30)
- opacity 属性 (32)
- transition 属性 (33)