Vue中的scoped属性

理解:

.vue 文件中,scoped<style> 标签的一个属性,作用是让样式只作用于当前组件 ,避免样式污染其他组件
scoped 让样式只在自己的组件内生效,不会影响到其他组件的同名元素

举例

没有 scoped 的情况(样式全局生效):
js 复制代码
<!-- ComponentA.vue -->
<style>
p {
  color: red;
}
</style>
js 复制代码
<!-- ComponentB.vue -->
<template>
  <p>我是B组件的文字</p> <!-- 这里的文字也会变成红色,因为ComponentA的样式是全局的 -->
</template>
scoped 的情况(样式仅当前组件生效):
js 复制代码
<!-- ComponentA.vue -->
<style scoped>
p {
  color: red;
}
</style>
<!-- 只有ComponentA里的<p>会变红,ComponentB的<p>不受影响 -->

原理:

Vue 会给加了 scoped 的组件内所有 DOM 元素自动添加一个唯一的属性(比如 data-v-xxxxxx),同时给样式也加上这个属性选择器,让样式只匹配当前组件的元素。

编译后大概是这样:

css 复制代码
/* 原样式 */
p { color: red; }

/* 编译后(带scoped) */
p[data-v-xxxxxx] { color: red; }

注意:

如果需要在当前组件中修改子组件的样式,scoped 可能会限制效果,这时可以用 ::v-deep 穿透:

vue 复制代码
<style scoped>
/* 穿透scoped,修改子组件的样式 */
::v-deep .child-component-class {
  margin-top: 20px;
}
</style>
相关推荐
hh随便起个名11 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
我是小路路呀12 小时前
element级联选择器:已选中一个二级节点,随后又点击了一个一级节点(仅浏览,未确认选择),此时下拉框失去焦点并关闭
javascript·vue.js·elementui
程序员爱钓鱼12 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
PineappleCoder12 小时前
工程化必备!SVG 雪碧图的最佳实践:ID 引用 + 缓存友好,无需手动算坐标
前端·性能优化
JIngJaneIL13 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
敲敲了个代码13 小时前
隐式类型转换:哈基米 == 猫 ? true :false
开发语言·前端·javascript·学习·面试·web
澄江静如练_13 小时前
列表渲染(v-for)
前端·javascript·vue.js
JustHappy13 小时前
「chrome extensions🛠️」我写了一个超级简单的浏览器插件Vue开发模板
前端·javascript·github
Loo国昌13 小时前
Vue 3 前端工程化:架构、核心原理与生产实践
前端·vue.js·架构