如何正确运用Vue的scoped和deep属性实现深度样式穿透?
- 内容介绍
- 文章标签
- 相关推荐
本文共计824个文字,预计阅读时间需要4分钟。
众周知,在组件中给`style`标签添加`scoped`属性,可以避免组件内样式对全局造成污染。`scoped`属性使得样式变为局部作用域,仅作用于当前组件,不会影响到外部组件。这样,组件内的样式变化不会影响到其他组件,保证了样式隔离。
原理如下:
- 在编译组件时,`scoped`属性会使得样式通过特殊的属性选择器进行封装,确保样式只应用于当前组件。- 这种封装后的样式选择器会添加一个基于组件名称的唯一属性,使得样式只作用于当前组件的元素。
众所周知,在组件中给style 标签添加属性 scoped 属性可以避免组件内样式对外界造成污染,scoped使得组件内的样式变成局域样式,只作用于当前组件。
原理如下-------
在编译组件的时候,如果当前组件内style标签上有scoped属性,那么会在当前所有标签上添加一个属性,而当前样式表内的所有末尾选择器后面也会加上该属性,那么就使得当前组件内的样式只会作用于当前组件内的元素。值得注意的是,当父组件,子组件同时使用scoped属性时,子组件最外层的标签既会被加上当前组件的hash值,又会加上父级组件的hash值,像这样
//子组件最外层标签
<div data-v-b45036b2 data-v-384b136e ></div>
但是有个问题------
在我们用scoped的时候回发现一个问题,就是我们在当前组件内使用的scoped,但是我想在当前组件内改变子组件的样式(非最外层标签),的时候会发现不好使。
<style scoped> .father-div .child-div{color:red;} </style>
因为到了浏览器上会解析成
<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/就可以在父组件内覆盖样式
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。
本文共计824个文字,预计阅读时间需要4分钟。
众周知,在组件中给`style`标签添加`scoped`属性,可以避免组件内样式对全局造成污染。`scoped`属性使得样式变为局部作用域,仅作用于当前组件,不会影响到外部组件。这样,组件内的样式变化不会影响到其他组件,保证了样式隔离。
原理如下:
- 在编译组件时,`scoped`属性会使得样式通过特殊的属性选择器进行封装,确保样式只应用于当前组件。- 这种封装后的样式选择器会添加一个基于组件名称的唯一属性,使得样式只作用于当前组件的元素。
众所周知,在组件中给style 标签添加属性 scoped 属性可以避免组件内样式对外界造成污染,scoped使得组件内的样式变成局域样式,只作用于当前组件。
原理如下-------
在编译组件的时候,如果当前组件内style标签上有scoped属性,那么会在当前所有标签上添加一个属性,而当前样式表内的所有末尾选择器后面也会加上该属性,那么就使得当前组件内的样式只会作用于当前组件内的元素。值得注意的是,当父组件,子组件同时使用scoped属性时,子组件最外层的标签既会被加上当前组件的hash值,又会加上父级组件的hash值,像这样
//子组件最外层标签
<div data-v-b45036b2 data-v-384b136e ></div>
但是有个问题------
在我们用scoped的时候回发现一个问题,就是我们在当前组件内使用的scoped,但是我想在当前组件内改变子组件的样式(非最外层标签),的时候会发现不好使。
<style scoped> .father-div .child-div{color:red;} </style>
因为到了浏览器上会解析成
<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/就可以在父组件内覆盖样式
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

