按钮button但我们点击时,它可以执行相应的功能
Button小部件是一个标准的Tkinter小部件,用于各种按钮。按钮是为用户设计的一个小部件,也就是说,如果用鼠标点击按钮,可能会开始一些操作。他们也可以包含文字和图像像标签。虽然标签可以以各种字体显示文本,但按钮只能以单一字体显示文本。一个按钮的文本可以跨越多行。
Python函数或方法可以与一个按钮相关联。如果以某种方式按下该按钮,将执行该功能或方法。
1 import tkinter as tk 2 from tkinter import ttk 3 win=tk.Tk() 4 win.title('GUI004') 5 6 aLabel=ttk.Label(win,text='A Label') 7 aLabel.grid(column=0,row=0) 8 9 def clickme(): 10 action.configure(text='*I have been clicked!') 11 aLabel.configure(foreground='red') 12 13 14 15 action=ttk.Button(win,text='Click Me',command=clickme) 16 action.grid(column=1,row=0) 17 18 win.mainloop()
【按钮的绑定函数方法】
第一种:在按钮组件被声明的时候用command属性声明,command属性接受一个函数名,注意函数名不要加引号。
第二种:使用bind方法,该方法是Misc这个类的一个方法
【网上小程序】
1 from tkinter import * 2 def xinlabel(): 3 global xin 4 s=Label(xin,text='增加一行') 5 s.pack() 6 7 8 xin=Tk() 9 b1=Button(xin,text='点我',command=xinlabel) 10 b1.pack() 11 12 xin.mainloop()
【注】
pack是tkinter中的一个布局管理模块
常用的选择(option)有:
- expand:当值为“yes”(或者YES tkinter模块中 “yes”==YES)时,side选项无效。组件显示在父配件中心位置;若fill选项为”both”,则填充父组件的剩余空间,其默认值为NO。
- fill:填充x(y)方向上的空间,当属性side=”top”或”bottom”时,填充x方向;当属性side=”left”或”right”时,填充”y”方向;当expand选项为”yes”时,填充父组件的剩余空间。
- side:定义停靠在父组件哪一边,TOP (默认), BOTTOM, LEFT, 或者 RIGHT.
【以下内容来源于网络】
pack布局
pack常用属性
属性名 | 属性简析 | 取值 | 取值说明 |
fill | 设置组件是否向水平或垂直方向填充 | X、Y、BOTH 和NONE | fill = X(水平方向填充)fill = Y(垂直方向填充)fill = BOTH(水平和垂直)NONE 不填充 |
expand | 设置组件是否展开,当值为YES时,side选项无效。组件显示在父容器中心位置;若fill选项为BOTH,则填充父组件的剩余空间。默认为不展开 | YES 、NO(1、0) | expand=YES expand=NO |
side | 设置组件的对齐方式 | LEFT、TOP、RIGHT、BOTTOM | 值为左、上、右、下 |
ipadx、ipady | 设置x方向(或者y方向)内部间隙(子组件之间的间隔) | 可设置数值,默认是0 | 非负整数,单位为像素 |
padx、pady | 设置x方向(或者y方向)外部间隙(与之并列的组件之间的间隔) | 可设置数值,默认是0 | 非负整数,单位为像素 |
anchor | 锚选项,当可用空间大于所需求的尺寸时,决定组件被放置于容器的何处 | N、E、S、W、NW、NE、SW、SE、CENTER(默认值为CENTER) | 表示八个方向以及中心 |
注意:上表中取值都是常量,YES等价于”yes”,亦可以直接传入字符串值。另外当界面复杂度增加时,要实现某种布局效果,需要分层来实现。
pack类提供了下列函数(使用组件实例对象调用):
函数名 | 描述 |
pack_slaves() | 以列表方式返回本组件的所有子组件对象。 |
pack_configure(option=value) | 给pack布局管理器设置属性,使用属性(option)= 取值(value)方式设置 |
propagate(boolean) | 设置为True表示父组件的几何大小由子组件决定(默认值),反之则无关。 |
pack_info() | 返回pack提供的选项所对应得值。 |
pack_forget() | Unpack组件,将组件隐藏并且忽略原有设置,对象依旧存在,可以用pack(option, …),将其显示。 |
location(x, y) | x, y为以像素为单位的点,函数返回此点是否在单元格中,在哪个单元格中。返回单元格行列坐标,(-1, -1)表示不在其中 |
size() | 返回组件所包含的单元格,揭示组件大小。 |
grid布局
grid布局又被称作网格布局,是最被推荐使用的布局。程序大多数都是矩形的界面,我们可以很容易把它划分为一个几行几列的网格,然后根据行号和列号,将组件放置于网格之中。使用grid 布局时,需要在里面指定两个参数,分别用row 表示行,column 表示列。需要注意的是 row 和 column 的序号都从0 开始。
grid属性设置
属性名 | 属性简析 | 取值 | 取值说明 |
row、column | row为行号,column为列号,设置将组件放置于第几行第几列 | 取值为行、列的序号,不是行数与列数 | row 和 column 的序号都从0 开始 |
sticky | 设置组件在网格中的对齐方式 | N、E、S、W、NW、NE、SW、SE、CENTER | 类似于pack布局中的锚选项 |
rowspan | 组件所跨越的行数 | 跨越的行数 | 取值为跨越占用的行数,而不是序号 |
columnspan | 组件所跨越的列数 | 跨越的列数 | 取值为跨越占用的列数,而不是序号 |
ipadx、ipady、padx、pady | 组件的内部、外部间隔距离,与pack的该属性用法相同 | 同pack | 同pack |
grid类提供了下列函数(使用组件实例对象调用):
函数名 | 描述 |
grid_slaves() | 以列表方式返回本组件的所有子组件对象。 |
grid_configure(option=value) | 给pack布局管理器设置属性,使用属性(option)= 取值(value)方式设置 |
grid_propagate(boolean) | 设置为True表示父组件的几何大小由子组件决定(默认值),反之则无关。 |
grid_info() | 返回pack提供的选项所对应得值。 |
grid_forget() | Unpack组件,将组件隐藏并且忽略原有设置,对象依旧存在,可以用pack(option, …),将其显示。 |
grid_location(x, y) | x, y为以像素为单位的点,函数返回此点是否在单元格中,在哪个单元格中。返回单元格行列坐标,(-1, -1)表示不在其中 |
size() | 返回组件所包含的单元格,揭示组件大小。 |
place布局。
最简单最灵活的一种布局,使用组件坐标来放置组件的位置。但是不太推荐使用,在不同分辨率下,界面往往有较大差异。
place属性设置
属性名 | 属性简析 | 取值 | 取值说明 |
anchor | 锚选项,同pack布局 | 默认值为 NW | 同pack布局 |
x、y | 组件左上角的x、y坐标 | 整数,默认值0 | 绝对位置坐标,单位像素 |
relx、rely | 组件相对于父容器的x、y坐标 | 0~1之间浮点数 | 相对位置,0.0表示左边缘(或上边缘),1.0表示右边缘(或下边缘) |
width、height | 组件的宽度、高度 | 非负整数 | 单位像素 |
relwidth、relheight | 组件相对于父容器的宽度、高度 | 0~1之间浮点数 | 与relx(rely)取值相似 |
bordermode | 如果设置为INSIDE,组件内部的大小和位置是相对的,不包括边框;如果是OUTSIDE,组件的外部大小是相对的,包括边框 | INSIDE、OUTSIDE(默认值INSIDE) | 可以使用常量INSIDE、OUTSIDE,也可以使用字符串形式”inside”、”outside” |
place类提供了下列函数(使用组件实例对象调用):
函数名 | 描述 |
place_slaves() | 以列表方式返回本组件的所有子组件对象。 |
place_configure(option=value) | 给pack布局管理器设置属性,使用属性(option)= 取值(value)方式设置 |
propagate(boolean) | 设置为True表示父组件的几何大小由子组件决定(默认值),反之则无关。 |
place_info() | 返回pack提供的选项所对应得值。 |
grid_forget() | Unpack组件,将组件隐藏并且忽略原有设置,对象依旧存在,可以用pack(option, …),将其显示。 |
location(x, y) | x, y为以像素为单位的点,函数返回此点是否在单元格中,在哪个单元格中。返回单元格行列坐标,(-1, -1)表示不在其中 |
size() | 返回组件所包含的单元格,揭示组件大小。 |