当前位置: 首页 > news >正文

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

文章目录

    • 目标
    • 修改样式
    • 动态添加/删除样式
    • 样式不生效

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

目标

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

在这里插入图片描述

修改样式

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

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

.el-timeline-item__tail{
}

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

:deep(.el-timeline-item__tail){
}

动态添加/删除样式

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

<div ref='timelineRef'><el-timeline>...</el-timeline>
</div>
const timelineRef = ref()

结合timeline:

const timeline = timelineRef.value.children[0]
const timelineItem = timeline.getElementsByClassName('el-timeline-item')

在这里插入图片描述

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

在这里插入图片描述
设置样式在active是变为蓝色,如:

.active_node{background-color:blue;
}

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

timelineItem[0].children[0].classList.add('active_node')

动态移除类:

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名重复的样式出现样式覆盖的情况。

解决方法:

<style lang="scss">
// 这里是动态添加的样式类
</style><style scoped lang="scss">
// 这里是其他样式类
</style>

最终效果:

在这里插入图片描述

http://www.lryc.cn/news/255734.html

相关文章:

  • GO设计模式——12、外观模式(结构型)
  • 一.初始typescript
  • mp3的播放
  • mixamo根动画导入UE5问题:滑铲
  • 容器资源视图隔离 —— 筑梦之路
  • 浅析嵌入式GUI框架-LVGL
  • Unity 关于SetParent方法的使用情况
  • Linux系统上RabbitMQ安装教程
  • ES通过抽样agg聚合性能提升3-5倍
  • c++详解栈
  • Zabbix结合Grafana打造高逼格监控系统
  • Linux设备树
  • 计算机方向的一些重要缩写和简介
  • ardupilot开发 --- git 篇
  • Linux基础命令练习2
  • Vue阶段笔记(有js包)
  • 执行npm run dev报Error: error:0308010C:digital envelope routines::unsupported问题
  • 解决微信小程序中 ‘nbsp;‘ 空格不生效的问题
  • vue el-select封装及使用
  • 了解linux计划任务
  • 等待和通知
  • vscode 如何将正则匹配到的字符前批量加字符
  • 上个月暴涨34.6%后,SoundHound AI股票现在还能买入吗?
  • Termux+Hexo结合内网穿透轻松实现安卓手机搭建博客网站发布公网访问
  • 程序员的养生指南(生命诚可贵,一人永流传!珍惜生命,从你我做起)
  • FP独立站怎么搭建?看这一篇就够了!强烈建议收藏!
  • 【华为OD题库-068】找出经过特定点的路径长度-java
  • 高性能队列框架-Disruptor使用、Netty结合Disruptor大幅提高数据处理性能
  • Linux学习笔记3 xshell(lnmp)
  • 分享几个可以免费使用GPT工具