scoped 和 deep的用法深究

前言

我们都知道在组件中给style标签添加scoped属性可以避免组件内样式对外界造成污染,scoped使得组件内的样式变成局域样式,只作用于当前组件。这个是怎么做到的呢?

原理

在编译组件的时候,如果当前组件内style标签上有scoped属性,那么会在当前所有标签上添加一个【data-v-hash】属性,而当前样式表内的所有末尾选择器后面也会加上该属性,那么久使得当前组件内的样式只会作用于当前组件内的元素。

值得注意的是,当父组件,子组件同时使用scoped属性时,子组件最外层的标签既会被加上当前组件的hash值,又会加上父级组件的hash值,像这样

//子组件最外层标签
<div data-v-b45036b2 data-v-384b136e ></div>
问题

在我们用scoped的时候回发现一个问题,就是我们在当前组件内使用的scoped,但是我想在当前组件内改变子组件的样式(非最外层标签),的时候会发现不好使

<style scoped>
.father-div .child-div{color:red;}
</style>

因为到了浏览器上会解析成

.father-div .child-div[data-v-b45036b2]{color:red;}

而标签上是这样的

<div data-v-384b136e ></div>

不好使的原因是应为父组件内样式内解析的是父组件的hash值,而子组件内标签上添加的是子组件的hash值,对应不上当然没效果,那怎么解决呢?

deep

当遇到这种困扰的时候我们可以另写一个style标签,然后不加scoped属性,来盖子组件的样式,当前这么写是可以的,但是不太优雅,这时我们可以用到/deep/属性,

.father-div /deep/ .child-div{color:red;}

当遇到"/deep/"的时候会将"/deep/"的位置替换成组件的hash值,解析成

.father-div[data-v-b45036b2] .child-div{color:red;}

这样只需要注意css的权重就可以覆盖子组件内的样式了,

小提示:子组件内最外层的样式由于是带了父子组件的两个hash值,所以是会被两头控制的,不需要/deep/就可以在父组件内覆盖样式

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 02:我只是想给你们当向导 刘炎和李路一出机场就被一辆吉普车接走了。 “你们好,我是王队派我来接你们的,我叫陈刚,...
    lasiya_1010阅读 406评论 0 0
  • 那些对岁月说过的情话,撂下的狠话,何尝不是一种恋爱。 字/ 静思践行 图/ 吾行吾摄 转身是爱, 再短暂也激荡, ...
    默燃就燃阅读 730评论 0 4
  • 要使用Image这个控件我们需要在最上面引入这个model 加载本地图片 加载工程中drawable中的图片 这里...
    Lazy1阅读 478评论 0 0

友情链接更多精彩内容