vue.js scss >>> 失效的问题

vue中,使用scss后,样式穿透失效的问题

如题,vue项目中样式使用scss时,对于需要穿透的样式,使用 >>> 穿透可能会不生效,解决办法也很简单:

将样式由:

css 复制代码
<style lang="scss" scoped>
.a >>> .b {
  font-size: 24px;
}
</style>

修改为:

css 复制代码
<style lang="scss" scoped>
.a /deep/ .b {
  font-size: 24px;
}
</style>

或者:

css 复制代码
<style lang="scss" scoped>
.a ::v-deep .b {
  font-size: 24px;
}
</style>

官方文档中对此也进行了说明:Scoped CSS,或者喜欢英文版的:Scoped CSS 英文版

vue中的template模板中,style中分为全局样式和局部样式,区别是是否存在scoped 属性,当你的组件中的样式中添加了scoped属性,表明你组件中的样式值作用于当前的组件,与其他页面的样式互不相关。

样式互不影响看似很不错,但是有些时候会存在一些问题,尤其是引用了第三方的ui组件后,需要修改其样式,而又不想去除scoped属性造成组件之间的样式污染,就需要使用到样式穿透,一般情况下使用 >>> 即可。但是在前端工具越来越强大方便的具体,使用一些例如scss或者less就可能造成问题。

相关推荐
~央千澈~19 分钟前
抖音弹幕游戏开发之第17集:添加日志系统·优雅草云桧·卓伊凡
linux·服务器·前端
JamesYoung797122 分钟前
第一部分 — 基础知识 项目框架与文件布局
前端·chrome
孟健26 分钟前
程序员就业率暴跌27.5%:我离开大厂5个月后,看懂了这件事
前端
卸任27 分钟前
Electron判断是内置摄像头还是接摄像头
前端·react.js·electron
NEXT061 小时前
普通函数与箭头函数的区别
前端·javascript·面试
全马必破三1 小时前
Webpack知识点汇总
前端·webpack·node.js
NEXT061 小时前
CommonJS 与 ES Modules的区别
前端·面试·node.js
猪头男2 小时前
【从零开始学习Vue|第八篇】深入组件——组件事件
前端
薛一半2 小时前
React三大属性之refs
前端·javascript·react.js
程序员林北北2 小时前
【前端进阶之旅】Svelte:编译即框架,让前端开发回归简洁
前端·javascript·vue.js·react.js·html5