vue样式穿透
本文转载自https://www.jb51.net/article/253428.htm#_label0,转载仅供学习使用.
scoped属性
我们在vue组件写样式一般是在<style>
标签里面,但是我们在这里的样式默认是全局样式,如果其它组件的class名取重复了则会导致样式污染。
所以vue支持在<style>
标签添加scoped
属性,这样当前组件的样式只会在当前样式生效,其它组件不会影响到。
例子如下:
<div class="page">
<span class="content">hello world</span>
</div>
<style lang="scss" scoped> .page {
.content {
color: aquamarine;
font-size: 20px;
}
} </style>
最终在浏览器渲染出来,div和span上都带有特殊属性
然后css的样式最终也会带上这些属性,根据这些属性找到元素。
这样子避免样式全局污染。
如果你的引入了第三方库,如果你想修改第三方库的样式,直接通过dom查找,修改样式是没有效果的。
比如我在项目引入了饿了么的组件库elementUI
。
<el-card class="box-card">
<span class="content">hello world</span>
</el-card>
如果我们想把padding改小一点,下面这样写是没有效果的。
<style lang="scss" scoped> .box-card {
.el-card__body {
padding: 10px;
}
} </style>
只看到默认的padding。我们写的样式没有渲染出来。
此时需要样式穿透,需要用到深度选择器/deep/
。
<style lang="scss" scoped> .box-card {
/deep/.el-card__body {
padding: 10px;
}
} </style>
样式穿透
vue都是通过深度选择器来样式穿透的。除了上面的讲/deep/
,我熟知的还有::v-deep
,>>>
。
那它们有何区别?
- 如果你使用的是css,没有使用css预处理器,则可以使用
>>>
,/deep/
,::v-deep
。 - 如果你使用的是less或者node-sass,那么可以使用
/deep/
,::v-deep
都可以生效。 - 如果你使用的是dart-sass,那么就不能使用
/deep/
,而是使用::v-deep
才会生效。
全栈爱好者,欢迎交流学习
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示