一、pack布局举例

#pack布局案例

import tkinter

baseFrame = tkinter.Tk()

#以下代码都是创建一个组件,然后布局

btn1 = tkinter.Button(baseFrame,text="A")

btn1.pack(side=tkinter.LEFT,expand=tkinter.YES,fill=tkinter.Y)

​

btn2 = tkinter.Button(baseFrame,text="B")

btn2.pack(side=tkinter.TOP,expand=tkinter.YES,fill=tkinter.BOTH)

​

btn2 = tkinter.Button(baseFrame,text="C")

btn2.pack(side=tkinter.RIGHT,expand=tkinter.YES,fill=tkinter.NONE)

​

btn2 = tkinter.Button(baseFrame,text="D")

btn2.pack(side=tkinter.LEFT,expand=tkinter.NO,fill=tkinter.Y)

​

btn2 = tkinter.Button(baseFrame,text="F")

btn2.pack(side=tkinter.BOTTOM,expand=tkinter.YES)

​

btn2 = tkinter.Button(baseFrame,text="G")

btn2.pack(anchor=tkinter.SE)

​

baseFrame.mainloop()

二、grid布局举例

1.通用使用方式:组件对象,grid(设置.......)

2.利用row,column编号,都是从0开始

3.sticky:N\E\S\W表示上下左右,用来决定组件从哪个方向开始

4.支持ipadx,padx等参数,跟pack函数含义一样

5.支持rowspan,columnspan,表示跨行,跨列数量


#pack布局案例

import tkinter

# baseFrame = tkinter.Tk()

# #以下代码都是创建一个组件,然后布局

# btn1 = tkinter.Button(baseFrame,text="A")

# btn1.pack(side=tkinter.LEFT,expand=tkinter.YES,fill=tkinter.Y)

#

# btn2 = tkinter.Button(baseFrame,text="B")

# btn2.pack(side=tkinter.TOP,expand=tkinter.YES,fill=tkinter.BOTH)

#

# btn2 = tkinter.Button(baseFrame,text="C")

# btn2.pack(side=tkinter.RIGHT,expand=tkinter.YES,fill=tkinter.NONE)

#

# btn2 = tkinter.Button(baseFrame,text="D")

# btn2.pack(side=tkinter.LEFT,expand=tkinter.NO,fill=tkinter.Y)

#

# btn2 = tkinter.Button(baseFrame,text="F")

# btn2.pack(side=tkinter.BOTTOM,expand=tkinter.YES)

#

# btn2 = tkinter.Button(baseFrame,text="G")

# btn2.pack(anchor=tkinter.SE)

#

#

# baseFrame.mainloop()

​

baseFrame2 = tkinter.Tk()

​

lb1 = tkinter.Label(baseFrame2,text="账号:")

lb1.grid(row=0,sticky=tkinter.W)

tkinter.Entry(baseFrame2).grid(row=0,column=1,sticky=tkinter.E)

​

lb2 = tkinter.Label(baseFrame2,text="密码:")

lb2.grid(row=1,sticky=tkinter.W)

tkinter.Entry(baseFrame2).grid(row=1,column=1,sticky=tkinter.E)

​

button = tkinter.Button(baseFrame2,text="登录").grid(row=2,column=1,sticky=tkinter.E)

​

baseFrame2.mainloop()

三、place布局

1.明确方位的摆放

2.相对位置布局,随意改变窗口大小会导致混乱。

3.使用place函数,分为绝对布局和相对布局,绝对布局使用x,y参数

4.相对布局使用relx.rely,relheight,relwidth.

四、源码

D61_ThreeFrameOfTkinter.py

https://github.com/ruigege66/Python_learning/blob/master/D61_ThreeFrameOfTkinter.py​

2.CSDN:https://blog.csdn.net/weixin_44630050(心悦君兮君不知-睿)

3.博客园:https://www.cnblogs.com/ruigege0000/

4.欢迎关注微信公众号:傅里叶变换,个人公众号,仅用于学习交流,后台回复”礼包“,获取大数据学习资料

Python连载61-tkinter三种布局的更多相关文章

  1. HTML的三种布局:DIV+CSS、FLEX、GRID

    Div+css布局 也就是盒子模型,有W3C盒子模型,IE盒子模型.盒子模型由四部分组成margin.border.padding.content. 怎么区别这两种模型呢,区别在于w3c中的width ...

  2. python实现单例模式的三种方式及相关知识解释

    python实现单例模式的三种方式及相关知识解释 模块模式 装饰器模式 父类重写new继承 单例模式作为最常用的设计模式,在面试中很可能遇到要求手写.从最近的学习python的经验而言,singlet ...

  3. Python实现定时执行任务的三种方式简单示例

    本文实例讲述了Python实现定时执行任务的三种方式.分享给大家供大家参考,具体如下: 1.定时任务代码 import time,os,sched schedule = sched.scheduler ...

  4. Python格式化输出的三种方式

    Python格式化输出的三种方式 一.占位符 程序中经常会有这样场景:要求用户输入信息,然后打印成固定的格式比如要求用户输入用户名和年龄,然后打印如下格式:My name is xxx,my age ...

  5. CSS三种布局模型是什么?

    在网页中,元素有三种布局模型:流动模型(Flow) 默认的.浮动模型 (Float).层模型(Layer).下面我们来看一下这三种布局模型. 三种布局模型介绍: 1.流动模型(Flow) 流动(Flo ...

  6. JavaGUI三种布局管理器FlowLayout,BorderLayout,GridLayout的使用

    三种布局管理器 流式布局FlowLayout package GUI; import java.awt.*; import java.awt.event.WindowAdapter; import j ...

  7. python字符串连接的三种方法及其效率、适用场景详解

    python字符串连接的方法,一般有以下三种:方法1:直接通过加号(+)操作符连接website=& 39;python& 39;+& 39;tab& 39;+& ...

  8. Python 列表(List) 的三种遍历(序号和值)方法

    三种遍历列表里面序号和值的方法: 最近学习python这门语言,感觉到其对自己的工作效率有很大的提升,特在情人节这一天写下了这篇博客,下面废话不多说,直接贴代码 #!/usr/bin/env pyth ...

  9. 记住 Python 变量类型的三种方式

    title: 记住变量类型的三种方式 date: 2017-06-11 15:25:03 tags: ['Python'] category: ['Python'] toc: true comment ...

  10. python更新数据库脚本三种方法

    最近项目的两次版本迭代中,根据业务需求的变化,需要对数据库进行更新,两次分别使用了不同的方式进行更新. 第一种:使用python的MySQLdb模块利用原生的sql语句进行更新 import MySQ ...

随机推荐

  1. cubic-bezier 个人学习理解

    cubic-bezier 三次贝塞尔曲线函数,是一种动画的速度曲线.根据动画设置的时间,速度相应变化 四个点 P0,P1,P2,P3,其中P0是起点,坐标(0,0),P3是终点,坐标(1,1) PI和 ...

  2. Nmap 使用

    0×01 前言 因为今天的重点并非nmap本身的使用,主要还是想借这次机会给大家介绍一些在实战中相对比较实用的nmap脚本,所以关于nmap自身的一些基础选项就不多说了,详情可参考博客端口渗透相关文章 ...

  3. CSS垂直居中的8种方法

    CSS垂直居中的8种方法 1.通过verticle-align:middle实现CSS垂直居中. 通过vertical-align:middle实现CSS垂直居中是最常使用的方法,但是有一点需要格外注 ...

  4. CSS文本居中显示

    因为一直为元素居中问题而困扰,所以决定把自己遇到和看到的方法记录下来,以便以后查看 如果要让inline或inline-block元素居中显示,则父元素css中包含text-align:center; ...

  5. angular 自定义服务封装自定义http请求

    在angular中将http请求,放置在一起封装成服务,可减少代码重复,方便使用 var ngpohttprest = angular.module('ngpohttprest', []); ngpo ...

  6. CSS - icon图标(icon font)

    1. 概念 这个小红点是图标,图标在CSS中实际上是字体. 2. 为什么出现本质是字体的图标? 2.1 图片增加了总文件的大小. 2.2 图片增加了额外的http请求,大大降低网页的性能. 2.3 图 ...

  7. Pytorch model saving and loading 模型保存和读取

    It is really useful to save and reload the model and its parameters during or after training in deep ...

  8. 基于金山快盘的Git服务器、快盘+ Git GUI 实现代码版本管理

        Git,这货堪称神器,用了它就再也不想用其他VCS了,就像上了高速就不想再走国道一样. Git的强大之处在于,你可以在局域网内的任何一个共享路径下创建仓库,而不需要运行任何服务.所有的操作都是 ...

  9. JS 一键复制插件应用 和 原生实现

    一.目前来说复制功能 clipboard.js基本可以兼容所有浏览器,可以任意复制文本,官方地址 https://clipboardjs.com/ 1.进入官方网站下载 然后引入 <script ...

  10. eclipse安装SVN插件的两种方法

    eclipse里安装SVN插件,一般来说,有两种方式: 直接下载SVN插件,将其解压到eclipse的对应目录里 使用eclipse 里Help菜单的“Install New Software”,通过 ...