如何使用Vue 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>

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

<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/就可以在父组件内覆盖样式

原创文章,作者:OGMOD,如若转载,请注明出处:https://www.wangzhanshi.com/n/15172.html

(0)
OGMOD的头像OGMOD
上一篇 2025年1月2日 12:15:22
下一篇 2025年1月2日 12:16:01

相关推荐

  • PHP8有哪些新特性

    1、JIT进入PHP8 JIT就是Just-In-Time的缩写,中文翻译为即时编译。它作为一种编译器策略,将代码表述为一种中间状态,在运行时将其转换为依赖于体系结构的机器码,并即…

    php 2025年1月2日
  • ThinkPHP中跨域请求设置的几种方式

    在 ThinkPHP 中支持跨域请求,通常有以下几种方式: 通过设置 HTTP 头信息 在控制器方法中设置在需要支持跨域的控制器方法中,设置允许跨域的 HTTP 头信息。可以使用h…

    php 2025年2月24日
  • PHP 7.x各个版本的新特性是什么

    PHP 7.x 各个版本的新特性 前言 上个月同事看见我写 $a = $a ?? ''; 问我这个写法是什么,还有这样的…

    php 2025年1月1日
  • PHP7新增了哪些运算符

    NULL 合并运算符其实是三元运算符的改造,减少的代码量 //原先的做法 //$lig = isset($_GET['lig'])?$_GET['li…

    2025年1月1日
  • PHP利用ffmpeg获取音频、视频的详细信息

    一、目的 使用PHP利用ffmpeg获取音频、视频的详细信息,音视频总时长、码率、视频分辨率、音频编码、音频采样频率、实际播放时间、文件大小。 二、下载并安装ffmpeg 1、下载…

    2024年12月17日
  • ubuntu如何安装lamp环境php7

    ubuntu安装lamp php7的方法:首先通过“sudo apt-get install”命令安装mysql;然后安装apache2;最后安装php7和apache2 php7…

    2025年1月1日
  • 如何使用PHP7生产环境队列Beanstalkd

    应用场景 为什么要用呢,有什么好处?这应该放在最开头说,一件东西你只有了解它是干什么的,适合干什么,才能更好的与自己的项目相结合,用到哪里学到哪里,学了不用等于不会,我们平时就应该…

    php 2025年1月1日
  • 在PHP7项目中数组的底层实现

    PHP 数组具有的特性 PHP 的数组是一种非常强大灵活的数据类型,在讲它的底层实现之前,先看一下 PHP 的数组都具有哪些特性。 可以使用数字或字符串作为数组健值 $arr&nb…

    2025年1月1日
  • PHP7操作MongoDB的增删改查和分页操作

    原文博客地址www.xiegaosheng.com/post/view?id=96; <?php /**  * Class MongodbCli…

    php 2025年1月1日
  • mac安装PHP7时出现的问题有哪些

    背景 前几天在mac上跑workrman,由于workerman需要开启多个进程,多进程需要pcntl扩展的支持,我之前那个brew安装的php71没有这个扩展,就直接卸载了php…

    php 2025年1月1日

发表回复

登录后才能评论