vue3中操作样式的变化

  1. 深度作用域选择器 :deep()

:deep()是Vue 3的推荐语法,取代了Vue 2中的>>>/deep/::v-deep等。

2.全局选择器 :global()

即使<style>标签有scoped属性,:global()内的选择器也会声明为全局样式,即不添加组件唯一属性,影响整个应用。

复制代码
<style scoped>
:global(.red) {
  color: red;
}
</style>

定义跨组件的统一样式,如主题色、公共字体。

不想额外创建非scoped的<style>块时,都可以用

3.插槽选择器 :slotted()

默认情况下,插槽内容(slot)的样式不受子组件scoped样式的影响。使用:slotted()可以专门选择并样式化父组件传递进插槽的内容。

  1. 样式模块化(CSS Modules)

CSS Modules为每个类生成唯一哈希名,实现样式真正隔离,避免全局污染。适合大型项目、组件库开发。

复制代码
<template>
  <p :class="$style.red">This should be red</p>
</template>

<style module>
.red {
  color: red;
}
</style>
相关推荐
用户69371750013849 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦9 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013849 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水10 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫12 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll12313 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
用头发抵命13 小时前
Vue 3 中优雅地集成 Video.js 播放器:从组件封装到功能定制
开发语言·javascript·ecmascript
蓝冰凌13 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js
奔跑的呱呱牛14 小时前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js