首页 > 其他分享 >关于vue的css样式对js动态添加的dom节点不生效问题的解决方法

关于vue的css样式对js动态添加的dom节点不生效问题的解决方法

时间:2022-08-28 12:35:34浏览次数:53  
标签:vue dom 样式 节点 添加 js class css

一、问题描述

开发的时候免不了有时候需要向某个节点appendchild,添加子节点,

但是如果是在vue中,就会发现通过操作dom的appendchild方式添加节点会出现样式对这些新增的节点无效。

二、解决思路

通过查看原始的节点与新增的节点发现,原始节点与新增节点的class都一样,但是原始的节点在class后面还会多出data-v-XXXXXXX这个属性,

然后再去查看引入的css样式同样发现在class名后面也会多加一个[data-v-XXXXXXX]的后缀。

原因

通过测试可以发现,这是因为vue文件中的style标签添加了scoped的原因,

而scoped的作用是为了保证这些css样式只会对当前vue文件(组件)生效,但是由于其他vue文件(组件)中也有可能会出现相同的class名相同的css样式,

于是vue就采用了添加随机后缀的方式防止class名重复的样式出现样式覆盖的情况。

三、解决办法

1.去掉scoped(不推荐)

把style标签的scoped去掉即可

当然这么做的前提是你得保证当前vue文件(组件)中的样式不会出现与其他组件样式class重名,否则可能会出现样式覆盖的情况。

2.::v-deep渗透(推荐)

完美解决!

::v-deep(#compassContent) {
  height: 28px;
  width: 28px;
}

标签:vue,dom,样式,节点,添加,js,class,css
From: https://www.cnblogs.com/echohye/p/16632541.html

相关文章

  • Vue3+vite+js 配置别名@报错
    Vue3+vite+js配置别名@报错vue3项目中配置vite.config.js时使用path模块报错,一直警告找不大到path模块原因:path模块是node.js内置的功能,但是node.js本身并不支持ts解决......
  • 论文笔记-Multi-Adversarial Domain Adaptation
    摘要文章提出了一种多对抗域自适应(MADAMulti-AdversarialDomainAdaptation)方法,它能够捕捉多模式结构以基于多个域鉴别器实现不同数据的细粒度对齐。ps:其实就......
  • JS基础学习(一)函数和对象
    函数定义方式1.第一种functionabs(x){if(x>=0){returnx;}else{return-x;}}2.第二种变量赋值的形式,注意最后有一个分号";......
  • 【面试题】Vue中的$router 和 $route的区别
    Vue中的$router和$route的区别点击视频讲解更加详细this.$route:当前激活的路由的信息对象。每个对象都是局部的,可以获取当前路由的path,name,params,query等属性......
  • vue中props定义对象和数组的区别
    扯开怎么定义,为什么要定义props,相信小伙伴们都知道,都会用了,但是有个问题,为什么有时候定义的是数组形式,有时候是对象形式呢?一句话:props对象形式才能给默认值和类型和必填......
  • NC20185 [JSOI2010]缓存交换
    题目原题地址:[JSOI2010]缓存交换题目编号:NC20185题目类型:堆、贪心时间限制:C/C++1秒,其他语言2秒空间限制:C/C++262144K,其他语言524288K1.题目大意Cache容量以及......
  • VUE 笔试题随笔-01
    vue的8个⽣命周期函数?1.beforeCreated2.created3.beforeMount4.mounted5.beforeUpdate6.updated7.beforeDestory8.destoryedv-show与v-if的区......
  • js无限debugger学习总结
    静态js代码debugger1.几千个含有debugger的script标签<script>debugger;</script><script>debugger;</script><script>debugger;</script>.........
  • Python random 的使用
    导入importrandom 随机数生成//用来生成[a,b]之间的随意整数,包括两个边界值。print(random.randint(0,9))//用来随机生成一个0到1之间的浮点数,包括零。0.15790......
  • Python 报错:json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char
    报错内容:json.decoder.JSONDecodeError:Expectingvalue:line1column1(char0) 报错代码:print(res.json()) 报错原因:打印请求返回值报错该接口返回值......