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

【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.kler.cn/a/162905.html

相关文章:

  • C语言 | Leetcode C语言题解之第556题下一个更大元素III
  • 华为大变革?仓颉编程语言会代替ArkTS吗?
  • 数据挖掘(九)
  • Qt_day4_Qt_UI设计
  • linux设置主机名
  • GIS空间分析案例---城市公共设施配置与服务评价
  • 初学vue3与ts:vue3选项式api获取当前路由地址
  • linux云服务器开启防火墙注意事件
  • 智能优化算法应用:基于食肉植物算法无线传感器网络(WSN)覆盖优化 - 附代码
  • 酿酒生产废水处理的设备需要哪些
  • 《论文阅读》用于情绪回复生成的情绪正则化条件变分自动编码器 Affective Computing 2021
  • 应用架构——集群、分布式、微服务的概念及异同
  • Spark大数据集群日常开发过程遇到的异常及解决思路汇总
  • RepVGG,结构重参数化让VGG风格的ConvNets再次强大起来
  • 人工干预与用户自主选择——算法安全背后的故事
  • Apache APISIX 体验指南
  • 与脾气不太好的领导,相处原则和相处技巧分享
  • Chrome 拓展开发系列:什么是 Chrome 拓展?
  • 常见客户端消息推送服务【Java后端】
  • wangEditor+vue上传图片到阿里云配置
  • 高性能队列框架-Disruptor使用、Netty结合Disruptor大幅提高数据处理性能
  • uniapp 使用 $emit和$on——$on中无法为data中的变量赋值
  • 大华DSS S2-045 OGNL表达式注入漏洞复现
  • 【软件推荐】文本转语音,语音转wav,导入ue5
  • P1046 [NOIP2005 普及组] 陶陶摘苹果题解
  • Django 用户验证与权限管理