PyQt5 基本语法(八):样式控制

本文介绍了PyQt5中QSS样式表的使用,包括基本概念、局部与全局设置方法。详细讲解了QSS的选择器,如通配符、类型、类、ID、属性、后代和子选择器。同时阐述了QSS的伪状态及其在控件状态管理中的应用。最后,概述了背景、边框、box、字体、外边距、内边距、定位和文本等声明属性。
摘要由CSDN通过智能技术生成

样式控制

一、 简介

1、 基本概念

QSS —— Qt 样式表

语法:

选择器:伪状态 {
   
    声明
}

用来自定义控件外观的一种机制

可以将其类比CSS;但是没有CSS强大

  • 选择器少
  • 属性少
  • 有些属性仅适用部分控件

2、 使用

2.1 局部设置

指定需要设置外观的控件,调用该控件的 setStyleSheet(qss_sheet_str)

参考作用范围:

  • 控件本身
  • 子控件

最终作用范围:

  • 通过选择器二次筛选
2.2 全局设置

指定全局的 QApplication 对象,调用 app.setStyleSheet(qss_sheet_str)

参考作用范围:

  • 应用程序所有控件

最终作用范围:

  • 通过选择器二次筛选
app = QApplication(sys.avgs)
# text.qss 是我们保存的样式表
with open("text.qss", "r") as f:
    content = f.read()
    app.setStyleSheet(content)

二、 QSS 样式表

1、 QSS 选择器

作用:指明哪些控件会受到样式的作用

1.1 通配符选择器

使用 * 来匹配对象内所有的控件

* {
   
    background-color: red;
}
1.2 类型选择器

通过控件类型来匹配控件(包含子类)

QWidget {
   
    background-color: red;  /* 匹配所有的 QWidget 控件,包括继承了 QWidget 类的子类 */
}
QPushButton {
   
    background-coloc: red;  /* 匹配所有的 QPushButton 控件,包括继承了 QPushButton 类的子类 */
}
1.3 类选择器

通过控件类型来匹配控件(不包含子类)

.QPushButton {
   
    background-color: red;  /* 匹配所有的 QPushButton 控件,不包含子类 */
}
1.4 ID 选择器

通过 objName 来匹配控件,注意其与CSS选择器里面的ID不一样,它可以有多个

#hehe {
   
	background-color: red;  /* 匹配 setObjectName("hehe") 的控件 */
}
1.5 属性选择器

通过属性值来匹配控件

QPushButton[name="warning"] {
   
    background-color: red;  /* 匹配 QPushButton类型控件内, setProperty("name", "warning") 的控件 */
}
QPushButton[name] {
   
    background-color: red;  /* 匹配 QPushButton类型控件内,拥有属性name这个键的控件 */
}
1.6 后代选择器

通过父控件的(直接或间接)子控件来筛选控件

QDialog QPushButton {
   
    background-color: red;  /* 只匹配所有QDialog中包含的QPushButton 控件 */
}
1.7 子选择器

通过父控件的(直接)子控件来筛选控件

QDialog>QPushButton {
   
    background-color: red;  /* 只匹配所有QDialog中,其儿子QPushButton控件,不包含孙子 */
}
1.8 子控件
  • 3
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SteveKenny

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值