Qt:25.QSS选择器(类型选择器、类选择器、id选择器、并集选择器、子控件选择器、伪类选择器)

目录

1.类型选择器:

2.类选择器:

3.id选择器:

4.并集选择器:

5.子控件选择器:

6.伪类选择器:


1.类型选择器:

  • 类型选择器用于选择应用样式的特定类型控件。

  • 它通过控件类型的名称来选择所有该类型的控件,并对其应用相应的样式。

  • 这种选择器会向下继承,比如在QWidget控件中设置了样式,在父控件范围内的其他继承自QWidget类的派生类控件,也会使用这个样式。

    控件类型
    {
    background-color: #007bff; /* 背景颜色 /
    color: white; /
    文字颜色 /
    border: 1px solid #0056b3; /
    边框 /
    border-radius: 4px; /
    圆角 /
    padding: 5px; /
    内边距 */
    }

2.类选择器:

  • 类选择器用于选择具有指定类名的控件。只针对某个类生效,不会对他的子类有继承。

  • 使用类选择器可以为特定组的控件应用样式,而无需指定每个控件的类型。

  • 类选择器在QSS中的语法与CSS类似,使用点号(.)后跟类名来定义。

    .控件类
    {
    background-color: #28a745; /* 背景颜色 /
    color: white; /
    文字颜色 /
    border: 1px solid #1e7e34; /
    边框 /
    border-radius: 4px; /
    圆角 /
    padding: 5px; /
    内边距 */
    }

3.id选择器:

  • ID选择器用于选择具有特定ID(控件的objectName)的控件,确保唯一性。

  • 每个ID在一个QSS文件中只能出现一次。

  • 使用ID选择器可以精确地为某个特定控件应用样式。

    #objectName
    {
    background-color: #007bff; /* 背景颜色 /
    color: white; /
    文字颜色 /
    border: 1px solid #0056b3; /
    边框 /
    border-radius: 4px; /
    圆角 /
    padding: 5px; /
    内边距 */
    }

4.并集选择器:

  • 并集选择器(grouping selector)用于将多个选择器组合在一起,使它们共享相同的样式。

  • 这种选择器在QSS中的语法与CSS类似,使用逗号(,)分隔多个选择器。

  • 类型可以混合,比如类型选择器+类选择器+id选择器。

    选择器1,选择器2,选择器n
    {
    background-color: #007bff; /* 背景颜色 /
    color: white; /
    文字颜色 /
    border: 1px solid #0056b3; /
    边框 /
    border-radius: 4px; /
    圆角 /
    padding: 5px; /
    内边距 */
    }

5.子控件选择器:

  • 子控件选择器(child control selector)在QSS中用于选择控件的子部件(sub-controls)。

  • 例如对于复合控件或者控件的特定部分(如滚动条的滑块、下拉框的箭头等),可以对其进行样式定制。

  • 子控件选择器的语法在QSS中使用双冒号(::)来区分子控件和主控件的关系。

    主控件类型::子控件名称
    {
    属性: 值;
    属性: 值;
    ...
    }

    //以下QSS代码将应用于QComboBox控件的下拉箭头部分,设置其颜色和背景。

    QComboBox::drop-down
    {
    background-color: #007bff; /* 箭头背景颜色 /
    color: white; /
    箭头颜色 */
    }

6.伪类选择器:

  • 根据控件所处在的状态进行选择。
  • 当控件具备某个状态时,样式生效。当控件不具备哪个状态时,样式不生效。
  • 比如按钮按下,输入框获得焦点等。
相关推荐
一袋米扛几楼9824 分钟前
【报错问题】彻底解决 TypeScript 报错 TS2769: No overload matches this call (JWT 篇)
linux·javascript·typescript
涵涵(互关)24 分钟前
语法大全-only-writer-two
前端·vue.js·typescript
huangql52026 分钟前
浏览器 Location API、History API、路由记录与支付跳转完全指南
前端
木斯佳28 分钟前
前端八股文面经大全:腾讯前端实习一面(2026-04-27)·面经深度解析
前端·八股·面经
sayamber33 分钟前
Kubernetes 生产环境避坑指南:10 个真实故障案例与解决方案
前端
清寒_1 小时前
分层理解AI架构,降低对AI复杂度的恐惧
前端·人工智能·ai编程
牧码岛1 小时前
Web前端之JavaScrip中的Array、Object、Map和Set详解
前端·javascript·web·web前端
Bigger1 小时前
😮‍💨 有了 AI 之后,我怎么感觉反而更累了?
前端·aigc·ai编程
Dxy12393102161 小时前
HTML中使用Canvas动态图形渲染:解锁Web交互新维度
前端·html·图形渲染
西陵1 小时前
如何实现 Claude 生成式 UI?一套可落地的工程方案
前端·人工智能·ai编程