vue中的css深度选择器

2024-09-03 09:28

本文主要是介绍vue中的css深度选择器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


在Vue.js项目中,尤其是在使用组件化开发时,我们时常需要修改组件内部的样式,但Vue的样式封装特性(如<style scoped>)会阻止外部样式直接作用于组件内部。为了应解决这个问题,Vue社区引入了深度选择器(也称为穿透选择器或阴影穿透选择器),让我们能够跨越组件的封装边界,对内部元素进行样式定制。

解决办法一:

由于scoped属性的防渗透作用,添加的样式不会生效,将scoped属性去掉,样式生效了.这种写法是作用到全局的,如果不严格规范class的命名,非常容易污染全局样式。这种写法,等同于写在全局样式文件中。

解决方法二:

保留scoped属性,使用深度选择器

1. /deep/

/deep/Vue 2.x中用于穿透组件样式封装的一种方式,兼容性:支持CSS预处理器(如Sass、Less)和CSS原生样式。注意:在Vue 3.x中,/deep/不再被官方直接支持

2. >>>

CSS原生语法:>>>是CSS原生中的深度选择器语法,用于穿透样式封装。但在Vue单文件组件(.vue)中,它并不总是被直接支持,因为Vue会将其视为普通CSS选择器的一部分。兼容性:仅在某些特定环境(如Webpack的css-loader配置中)和原生CSS中有效,Vue单文件组件中通常需要特定配置才能使用。注意:在Vue 3.x中,>>>同样不再被推荐使用

3. ::v-deep

Vue 3.x中的推荐用法::v-deepVue 3.x中引入的官方深度选择器,用于替代Vue 2.x中的/deep/和原生CSS中的>>>兼容性:支持CSS预处理器和CSS原生样式,是Vue 3.x中推荐使用的深度选择器。

4. :deep

特殊用法:在Vue 3的Composition API中,可以通过v-deep()函数在<style>标签中动态应用深度选择器。这不是CSS语法的一部分,而是Vue 3特有的模板编译特性。用法:通常在<style>标签的scoped属性下,结合v-bind:classv-bind:style在模板中动态绑定样式时使用。

总结

Vue 2.X

<style scoped>
.parent /deep/ .child {/* 样式规则 */
}
</style>

或者使用>>>(需要配置支持):

<style scoped>
.parent >>> .child {/* 样式规则 */
}
</style>
Vue 3.x
<style scoped>
:deep(.van-card__thumb) {width: 120px;display: flex;justify-content: space-around;
}
</style>

新的vue3.0 单文件规范中,如果你还是使用写法3,会碰到如下警告:

[@vue/compiler-sfc] ::v-deep usage as a combinator has been deprecated. Use :deep(<inner-selector>) instead.

写法3在vue3.0中已经被不推荐使用,在开发vue3.0项目的时候,使用写法4

这篇关于vue中的css深度选择器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132618

相关文章

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

在React中引入Tailwind CSS的完整指南

《在React中引入TailwindCSS的完整指南》在现代前端开发中,使用UI库可以显著提高开发效率,TailwindCSS是一个功能类优先的CSS框架,本文将详细介绍如何在Reac... 目录前言一、Tailwind css 简介二、创建 React 项目使用 Create React App 创建项目

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Python实现html转png的完美方案介绍

《Python实现html转png的完美方案介绍》这篇文章主要为大家详细介绍了如何使用Python实现html转png功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 1.增强稳定性与错误处理建议使用三层异常捕获结构:try: with sync_playwright(