当前位置:首页 > 科技  > 软件

Vue中Scope是怎么做的样式隔离的?

来源: 责编: 时间:2024-01-04 09:32:19 367观看
导读scope样式隔离在 Vue 中,样式隔离是通过 scoped 特性实现的。当在一个组件的 <style> 标签上添加 scoped 特性时,Vue 会自动为这个样式块中的所有选择器添加一个唯一的属性,以确保这些样式只对当前组件生效,从而达到样式

scope样式隔离

在 Vue 中,样式隔离是通过 scoped 特性实现的。当在一个组件的 <style> 标签上添加 scoped 特性时,Vue 会自动为这个样式块中的所有选择器添加一个唯一的属性,以确保这些样式只对当前组件生效,从而达到样式隔离的效果。WdV28资讯网——每日最新资讯28at.com

以下是 scoped 样式隔离的基本原理:WdV28资讯网——每日最新资讯28at.com

  1. 「唯一属性添加:」 在编译过程中,Vue 会将样式块中的每个选择器都转换为一个带有唯一属性的选择器。例如,如果有一个类似 .my-class 的选择器,可能会被转换成类似 .my-class[data-v-xxxxxxx] 的形式,其中 data-v-xxxxxxx 是一个唯一的属性。
  2. 「属性注入到组件元素:」 在组件渲染时,Vue 会自动将这个唯一的属性注入到组件的根元素上。这样,样式块中的选择器就会匹配到具有相同唯一属性的元素,从而确保样式只会应用到当前组件。

下面是一个简单的示例:WdV28资讯网——每日最新资讯28at.com

<template>  <div class="my-component">    <p class="my-class">This is a paragraph.</p>  </div></template><style scoped>.my-class {  color: red;}</style>

在这个例子中,<style scoped> 中的样式会被转换,使得 .my-class 成为 .my-class[data-v-xxxxxxx]。然后,这个唯一属性 data-v-xxxxxxx 会被注入到组件根元素上,使得样式只会应用到当前组件内的元素,而不会影响到其他组件。WdV28资讯网——每日最新资讯28at.com

这种样式隔离的机制保证了组件之间的样式不会相互干扰,是 Vue 组件化开发中的一个重要特性。WdV28资讯网——每日最新资讯28at.com

如何打破scope的限制?

在 Vue 中,scoped 样式的设计初衷是为了实现组件样式的隔离,以防止样式污染和冲突。然而,有时候可能需要打破 scoped 样式的限制。以下是一些常见的方法:WdV28资讯网——每日最新资讯28at.com

1. 使用 ::v-deep 或 /deep/:

在 scoped 样式中,可以使用 ::v-deep 或 /deep/ 伪类选择器来打破样式的封装,以便选择子组件中的元素。需要注意的是,这两个选择器在 Vue 2.x 中是等效的,但在 Vue 3.x 中 ::v-deep 被废弃,取而代之的是 /deep/。WdV28资讯网——每日最新资讯28at.com

<style scoped>::v-deep .my-class {  color: blue;}/* 或者在 Vue 3.x 中可以使用 /deep/ *//deep/ .my-class {  color: blue;}</style>

这样可以让样式穿透到子组件中。WdV28资讯网——每日最新资讯28at.com

2. 使用全局样式:

如果确实需要在多个组件之间共享样式,可以考虑将样式定义为全局样式而不使用 scoped 特性。WdV28资讯网——每日最新资讯28at.com

<style>.my-class {  color: red;}</style>

3. 使用深度选择器:

在 Vue 3.x 中,可以使用 ::v-slotted 深度选择器来选择插槽中的元素。这在处理插槽样式时非常有用。WdV28资讯网——每日最新资讯28at.com

<style scoped>::v-slotted(.my-class) {  color: green;}</style>

在使用这些方法时,需要谨慎考虑样式的全局性和可维护性,以确保样式的修改不会产生意外的副作用。打破 scoped 样式的限制可能会导致不易维护的代码,因此建议仅在确实需要的情况下使用。WdV28资讯网——每日最新资讯28at.com

deep

在 Vue 2.x 中,使用 ::v-deep 或 /deep/ 可以穿透 scoped 样式的限制的原因与其实现方式有关。这两个选择器的作用是告诉样式引擎在处理选择器时要忽略 scoped 样式中的作用域,从而可以选择到子组件中的元素。WdV28资讯网——每日最新资讯28at.com

实际上,::v-deep 和 /deep/ 是 Vue 对样式处理引擎进行了处理,使其能够正确解析这些选择器,然后将样式应用到相应的 DOM 元素上。WdV28资讯网——每日最新资讯28at.com

在 Vue 3.x 中,::v-deep 被废弃,取而代之的是 /deep/ 或 ::v-slotted。这种变化是为了更好地与 Web 标准兼容,因为 ::v-deep 不是 CSS 规范的一部分。WdV28资讯网——每日最新资讯28at.com

但是,穿透 scoped 样式的做法实际上打破了组件的封装性,可能导致样式的不可预测性和不易维护性。在使用这种方式时需要权衡利弊,并确保清晰地了解可能产生的影响。最好的做法是遵循组件的封装性原则,将样式限制在组件内部,以避免全局样式的冲突和混乱。WdV28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-57372-0.htmlVue中Scope是怎么做的样式隔离的?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: JS小知识,如何将 CSV 转换为 JSON 字符串

下一篇: .NET下优秀的IOC容器框架Autofac的使用方法,实例解析

标签:
  • 热门焦点
  • 俄罗斯:将审查iPhone等外国公司设备 保数据安全

    iPhone和特斯拉都属于在各自领域领头羊的品牌,推出的产品也也都是数一数二的,但对于一些国家而言,它们的产品可靠性和安全性还是在限制范围内。近日,俄罗斯联邦通信、信息技术
  • 如何正确使用:Has和:Nth-Last-Child

    我们可以用CSS检查,以了解一组元素的数量是否小于或等于一个数字。例如,一个拥有三个或更多子项的grid。你可能会想,为什么需要这样做呢?在某些情况下,一个组件或一个布局可能会
  • 使用LLM插件从命令行访问Llama 2

    最近的一个大新闻是Meta AI推出了新的开源授权的大型语言模型Llama 2。这是一项非常重要的进展:Llama 2可免费用于研究和商业用途。(几小时前,swyy发现它已从LLaMA 2更名为Lla
  • Python异步IO编程的进程/线程通信实现

    这篇文章再讲3种方式,同时讲4中进程间通信的方式一、 Python 中线程间通信的实现方式共享变量共享变量是多个线程可以共同访问的变量。在Python中,可以使用threading模块中的L
  • 雅柏威士忌多款单品价格大跌,泥煤顶流也不香了?

    来源 | 烈酒商业观察编 | 肖海林今年以来,威士忌市场开始出现了降温迹象,越来越多不断暴涨的网红威士忌也开始悄然回归市场理性。近日,LVMH集团旗下苏格兰威士忌品牌雅柏(Ardbeg
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己&ldquo;当家&rdquo;的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • iQOO 11S或7月上市:搭载“鸡血版”骁龙8Gen2 史上最强5G Soc

    去年底,iQOO推出了“电竞旗舰”iQOO 11系列,作为一款性能强机,iQOO 11不仅全球首发2K 144Hz E6全感屏,搭载了第二代骁龙8平台及144Hz电竞屏,同时在快充
  • 引领旗舰级影像能力向中端机普及 OPPO K11 系列发布 1799 元起

    7月25日,OPPO正式发布K系列新品—— OPPO K11 。此次 K11 在中端手机市场长期被忽视的影像板块发力,突破性地搭载索尼 IMX890 旗舰大底主摄,支持 OIS
  • 三翼鸟智能家居亮相电博会,让用户体验更真实

    2021电博会在青岛国际会展中心开幕中,三翼鸟直接把“家”搬到了现场,成为了展会的一大看点。这也是三翼鸟继9月9日发布了行业首个一站式定制智慧家平台后的
Top