如何动态添加class样式

如何动态添加class样式,第1张

1

如果学WEB,w3school是一个非常有用的网站,总能找到你需要的东西。

2

如下图所示,这是w3school中对jquery属性 *** 作方法的介绍。

3

attr()可以设置和获取class属性。

设置:

$("img").attr("class","intro")

获取:

$("img").attr("class")

注:

attr()是将原有的class属性设置为新的class属性,不是在原来的基础上添加新的class属性。

4

那如果要在原来的class样式基础上添加新的样式要使用什么方法呢?

那就是addClass()方法。

5

addClass()可以添加一个或多个class属性。

添加一个class属性:

$("img").addClass("intro")

添加多个class属性:

$("img").addClass("intro1 intro2")//属性之间用空格分隔。

注:

当多class样式作用于一个元素上时,后添加的class样式会覆盖之前的。

6

示例:

$(document).ready(function(){ $("button").click(function(){$("p:first").addClass("intro1 intro2") })})

<style type="text/css">.intro1{font-size:120%color:red}.intro2{color:blue}</style>

<p>This is a paragraph.</p>

添加了两个class样式,后面的样式覆盖了之前的。所以字体显示是蓝色的。

在vue中当我们要实现点击元素动态添加类名时,我们不能像JQ那样去用(xxx.addClass(‘class’).siblings().removeClass(‘class’))实现,那我们应该怎样去做呢

解决方案:

1.在data里面申明一个属性,默认值最好为数字类型,并且不得大于当前元素+所有兄弟元素的length,可以默认为0(第一个元素选中)

2.在当前元素中添加动态class: “:class”,使用v-bind进行绑定

3.给元素点击事件,传入当前元素的index,把元素当前的index赋值给data里面的申明的属性,这样就可以点击实现该效果

一.首先给想要添加class的元素,通过v-bind绑定一个class

二.在data中声明一个变量activeClass

三.在点击事件中

四.在style里面写想要的样式就可以了

很简单。

if(location.href=='1.html'){

    $('.hexagon-in2').addClass('.active')

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/11508107.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-16
下一篇2023-05-16

发表评论

登录后才能评论

评论列表(0条)

    保存