关于vue中的scoped

对于scoped,之前只知道它可以避免父组件中的样式渗透到子组件中。原理是给每个组件添加唯一属性,而位于最后的选择器也对应地赋予属性限制。

简单地认为只要加了scoped就完全地独立开来了是错误的。下面举几个容易碰到的问题。

父组件和子组件设置样式

父组件

xml 复制代码
<template>
  <div class="container">
    <Child />
  </div>
</template>

<script>
import Child from "./components/Child.vue";
export default {
  components: {
    Child,
  },
};
</script>

<style scoped>
.container {
  width: 100px;
  height: 100px;
  background-color: red;
}

.child-container {
  color: blue;
}
</style>

子组件

xml 复制代码
<template>
   <div class="child-container">child</div>
</template>

<style scoped>
.child-container {
  color: pink;
}
</style>

子组件的div的字体是蓝还是粉?

答案是蓝。因为子组件的根元素也被加了父组件的唯一属性。那么第一个文件和第二个文件都对同一个元素设置样式,最终以父组件的为准。

再看一个例子,父组件同上,子组件

xml 复制代码
<template>
  <div>
    <div class="child-container">child</div>
  </div>
</template>

<style scoped>
.child-container {
  color: pink;
}
</style>

子组件的div的字体是蓝还是粉?

答案是粉。因为只对子组件的根元素添加了父组件的唯一属性,再深入的元素都没有添加了。所以父组件的样式是无效的,没有一个class为child-container且有父组件属性的元素,只有子组件自己的样式才是有效的。

样式失效

参考文章如下,写的很好。

juejin.cn/post/731003...

原先是4个div,拓展一下变为5个div,这种情况如何使用深度选择器去解决呢?

父组件

xml 复制代码
<script setup>
import Component from "./components/Child.vue";
</script>

<template>
  <div class="div1">
    div1
    <div class="div2">
      div2
      <Component />
    </div>
  </div>
</template>

<style scoped>
.div1 {
  color: red;
}

.div1 .div2 {
  color: blue;
}

.div1 .div2 .div3 {
  color: green;
}

.div1 .div2 .div3 :deep(.div4) {
  color: yellow;
}

.div1 .div2 .div3 :deep(.div4) .div5 {
  color: purple;
}
</style>
</style>

子组件

xml 复制代码
<script setup>
</script>

<template>
  <div class="div3">
    div3
    <div class="div4">
      div4
      <div class="div5">div5</div>
    </div>
  </div>
</template>

<style scoped>
.div3 {
}
.div4 {
}
.div5 {
}
</style>

都是直接给子组件的根元素的第一个子元素加上:deep()即可,使得选择器的属性限制都退到子组件的根元素上。

附上深度选择器的写法

注意

vue2没什么问题,vue3的组件可以不只有一个根元素,当只有一个根元素还是符合上述规律。但是如果不止一个根元素,则子组件下的所有元素都不会添加父组件的唯一属性。

最佳实践

综上所述,最佳实践是全部用scoped,在需要深度选择器的地方再添加深度选择器。

相关推荐
微祎_3 分钟前
写给新手的 triton-inference-server-ge-backend:昇腾Triton推理服务后端到底是啥?
前端·人工智能·cann
烂不烂问厨房6 分钟前
两张图片拼接在一起中间有条白线
前端
掘金安东尼9 分钟前
浏览器跨域窗口通信技术调研:window.open 与 postMessage
前端
Highcharts.js2 小时前
缺失数据可视化图表开发实战|Highcharts创建人员出生统计面积图表示例
开发语言·前端·javascript·信息可视化·highcharts·图表开发
LaughingZhu9 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫9 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
小鹏linux10 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水11 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger11 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)11 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue