前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Qt QSS 属性选择器使用详解

Qt QSS 属性选择器使用详解

作者头像
我与梦想有个约会
发布2020-01-05 14:54:03
2.5K0
发布2020-01-05 14:54:03
举报
文章被收录于专栏:jiajia_dengjiajia_deng

Qt 的属性选择器是其独有的,非常类似 CSS 的类选择器,但是由于 CSS 的类选择器可以设置多个,所以一个标签只要设置多个的 class 就可以实现不同的效果了甚至重叠效果。但是 Qt 的类选择器没有那么强大,他不能给控件设置多个类标识。所以就有了属性选择器这么个东西。

属性选择器要点

  • 属性选择器应用于同一个类型下不同实现效果(如希望 QPushButton 有两套通用样式)
  • 属性选择器对象需要先设置 QVariant 支持的类型属性 setProperty(“key”, “value”)
  • 属性选择器对象设置的属性 key 不能用 class(实测无效)

示例代码

代码语言:javascript
复制
Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);

    QHBoxLayout* mainLayout = new QHBoxLayout;

    QPushButton* confirm = new QPushButton;
    confirm->setText("confirm");
    confirm->setProperty("level", "dangrous");

    QPushButton* cancel = new QPushButton;
    cancel->setText("cancel");
    cancel->setProperty("level", "normal");

    mainLayout->addWidget(confirm);
    mainLayout->addWidget(cancel);

    cancel->setProperty("urgent", true);

    setStyleSheet("QPushButton { color: #FFF; border: 0; height: 30px; width: 100px; }"
                  "QPushButton[level='dangrous'] { background-color: red; }"
                  "QPushButton[level='normal'] { background-color: blue; }");

    this->setLayout(mainLayout);
}

最终效果

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年4月1日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 属性选择器要点
  • 示例代码
  • 最终效果
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档