QT自定义类中setStyleSheet设置样式无效

遇到一个控件样式不对的问题。

原因是,下方代码原先是写在mainwindow.cpp中的构造函数的,如下:

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    ui->textedit->setStyleSheet("border:0px; background-color:#FFFFFF");
}

当我自定义了一个LNTextEdit.cpp类后,并继承了QTextEdit。为了实现某种自定义效果

故我讲上方代码中的ui->textedit->setStyleSheet这句代码迁移到了LNTextEdit.cpp中,如下:

#include "lntextedit.h"

LNTextEdit::LNTextEdit(QWidget *parent)
    : QTextEdit(parent)
{
     this->setStyleSheet("border:0px; background-color:#FFFFFF");
}

当我重新运行代码时,发现样式没有生效,背景色和边框都恢复到了原始状态。

原因如下:

控件的set StyleSheet方法是会被覆盖的,当我们在mainwindow.cpp中写时,

由于ui->setupUi(this);这句代码中其实已经设置过一遍textedit的set StyleSheet,代码如下:

进入到 ui->setupUi(this);这个方法中,可以看到上图中的这段代码,这段代码是有qdesigner自动生成的,详细可见:QT新增自定义控件类并在QT Designer中将系统父类替换

所以在mainwindow.cpp中,设置setstylesheet,实际上是把上面这句代码覆盖掉了,因此能正常显示。先来后到,后写的会覆盖先写的。

然而写在自定义类LNTextEdit中构造函数的这句setstylesheet,是被上图这句setstylesheet给覆盖了,因为是写在了构造函数中,先执行了构造函数,再执行下面的这句setstylesheet。

所以样式失效了。

我又检查了一下我的ui文件,发现我并没有在textedit的stylesheet中写任何东西

然后仔细看了下,应该是多敲了一个空格,如下图:

最右方的返回红色按钮其实是可以点击的 ,也就是说确实该动过ui文件中textedit的stylesheet属性,导致在自动生成 ui->setupUi(this);这句代码时,加入了一句setsheetstyle

其实在ui文件中,也就是xml形式中,也可以看到这句话:

解决方案:点击下ui视图中,textedit的stylesheet属性,点击撤回按钮。

这样就能保证不在setupui方法中,自动设置stylesheet了,也保证了在自定义类中的setstylesheet不被覆盖了

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值