场景
昨天还是在别人写的项目的基础上进行UI优化的时候,遇到一个覆盖element样式在生产环境失效的问题。
首先我将.el-main这个类的覆盖样式写在了app.vue里,当然写在公共的css里也一样会遇到这个问题。
.el-main {
padding: 0;
}
其次element的css样式文件是在main.js里引入的。
开发环境一切正常,我覆盖的el-main的类起作用了。
但是打包放到生产环境,发现padding: 0;并没有生效。
解决
从开发者工具那里查看样式可以看到,element的原生的样式,将自己写的样式给覆盖了,目前优先级是一样的,可能打包后引用顺序问题导致。自己写的样式先有,element的原生样式后有。
解决方案是给自己写的样式提高了下优先级就好了。
#app {
.el-main