遇到一个控件样式不对的问题。
原因是,下方代码原先是写在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不被覆盖了