【Vue】修改组件样式并动态添加样式

文章目录

注意:类似效果el-step也可以实现,可以不用手动实现。这里只是练习。

目标

使用组件库中的组件,修改它的样式并动态添加/删除样式。

修改样式

组件中的一些类可能添加样式无法生效。如Element Plus中的Timeline 时间线 | Element Plus (element-plus.org)

假设想修改两个圆之间的线的长度,由于组件没有暴露相关的类名,我们需要自己修改它。浏览器F12可知,它的类名为:.el-timeline-item__tail,直接写样式无法生效:

css 复制代码
.el-timeline-item__tail{
}

:deep进行样式穿透可以生效:注意,deep与后面的括号不能有空格

css 复制代码
:deep(.el-timeline-item__tail){
}

动态添加/删除样式

动态添加/删除样式需要操作DOM ,这里要使用ref。由于这里使用的是组合式API,没有this,获取ref的方法是:

html 复制代码
<div ref='timelineRef'>
	<el-timeline>
		...
	</el-timeline>
</div>
javascript 复制代码
const timelineRef = ref()

结合timeline:

javascript 复制代码
const timeline = timelineRef.value.children[0]
const timelineItem = timeline.getElementsByClassName('el-timeline-item')

其中,每个li代表item,包含节点node(圆圈)+下面的竖线tail。最后一个节点下面的tail不显示。

设置样式在active是变为蓝色,如:

css 复制代码
.active_node{
	background-color:blue;
}

那么在比如触发到这一步是就给此节点添加类active_node

javascript 复制代码
timelineItem[0].children[0].classList.add('active_node')

动态移除类:

javascript 复制代码
timelineItem[0].children[0].classList.remove('active_node')

需要注意的是:

  • F12看样式源代码,节点node颜色是background-color,线tail颜色是border的颜色
  • 由上面截图可知,children[0]表示tail,children[1]为node

样式不生效

动态添加完类后发现样式不生效。可以确认类是已经添加了的。原因:vue 中 通过js插入的dom 无法生效css_vue通过方法里拼接的dom自定义组件无法识别-CSDN博客

这是因为vue文件中的style标签添加了scoped,而scoped的作用是为了保证css样式只对当前vue文件(组件)生效,但是由于其他vue文件(组件)中也有可能会出现相同的class名相同的css样式,于是vue就采用了添加随机后缀的方式防止class名重复的样式出现样式覆盖的情况。

解决方法:

html 复制代码
<style lang="scss">
// 这里是动态添加的样式类
</style>

<style scoped lang="scss">
// 这里是其他样式类
</style>

最终效果:

相关推荐
nvd1114 分钟前
企业级 LLM 实战:在受限环境中基于 Copilot API 构建 ReAct MCP Agent
前端·copilot
+VX:Fegn089520 分钟前
计算机毕业设计|基于springboot + vue校园实验室管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Dragon Wu23 分钟前
TailWindCss cva+cn管理样式
前端·css
烤麻辣烫27 分钟前
Web开发概述
前端·javascript·css·vue.js·html
Front思38 分钟前
Vue3仿美团实现骑手路线规划
开发语言·前端·javascript
徐同保40 分钟前
Nano Banana AI 绘画创作前端代码(使用claude code编写)
前端
Ulyanov41 分钟前
PyVista与Tkinter桌面级3D可视化应用实战
开发语言·前端·python·3d·信息可视化·tkinter·gui开发
计算机程序设计小李同学41 分钟前
基于Web和Android的漫画阅读平台
java·前端·vue.js·spring boot·后端·uniapp
干前端43 分钟前
Message组件和Vue3 进阶:手动挂载组件与 Diff 算法深度解析
javascript·vue.js·算法
lkbhua莱克瓦2444 分钟前
HTML与CSS核心概念详解
前端·笔记·html·javaweb