QSS样式表的选择器

一个最简单的样式设置格式如下

QWidget {
    background-color: black;
}

将样式应用到对应的控件

QWidget* w = new QWidget;
w->setStyleSheet("QWidget {background-color: black;}");

样式表中控件的设置有多种方式

通用选择器

/*匹配所有控件*/
*{}

类型选择器

/*匹配所有该类型的控件*/
QWidget{}

ID选择器

//控件可以设置自己的名字
QWidget* w = new QWidget;
w->setObjectName("specialWidget");
QWidget#specialWidget{}

/*可以同时匹配多个*/
QWidget#specialWidget1, #specialWidget2{}

ID选择器(模糊查找)

/*匹配所有ID以groupWidget开头的控件*/
QWidget[objectName^="groupWidget"]{}

/*匹配所有ID包含Widget的控件*/
QWidget[objectName^="Widget"]{}

属性选择器

/*匹配选中的复选框*/
QCheckBox[checked="true"]{}

也可以使用自定义的属性

QWidget* w = new QWidget;
w->setObjectName("specialWidget");
w->setProperty("state", "default");
/*匹配state为default的QWidget控件*/
QWidget[state="default"]{}

状态选择器

/*匹配QPushButton鼠标悬停在按钮上的样式*/
QPushButton:hover{}

子控件

/*匹配QTableWidget(表格)的项(单元格)*/
QTableWidget::item{}

组合选择器

/*匹配QHeaderView中所有子控件类型为QWidget的控件*/
QHeaderView QWidget {}

一些例子

选择器可以组合使用

/*匹配ID为Mix-leftTitleWidget和ID以Mix-Icon开头的控件*/
QWidget#Mix-leftTitleWidget, [objectName^="Mix-Icon"] {}

/*匹配ID以CoalYard-Data开头,且state属性为false时候的控件*/
QLabel[objectName^="CoalYard-Data"][state = "false"] {}

/*匹配ID以Effluent-button开头,且鼠标悬停在按钮上的控件*/
QPushButton[objectName^="Effluent-button"]:hover {}

/*匹配日历控件中日期子控件的工具按钮子控件*/
QDateTimeEdit QCalendarWidget QToolButton {}

/*匹配表格控件中,被选中的单元格,鼠标悬停在上面时的控件*/
QTableWidget:item:selected:hover {}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值