vue动态绑定class的几种方式

vue动态绑定class的几种方式

对象方法
最简单的绑定,也是比较常用的方法(这里的active加不加单引号都可以,以下也一样都能渲染)

:class="{ 'active': isActive }"

判断是否绑定一个active

:class="{'active':isActive==-1}"  

:class="{'active':isActive==index}"

绑定并判断多个

1、用逗号隔开
:class="{ 'active': isActive, 'sort': isSort }"
2、放在data里面
//可以把绑定的对象写在一个变量放在data里面
:class="classArr"
data() {
  return {
    classArr:{ active: true, sort:false }
  }
}
3、使用computed属性
:class="classArr"
data() {
  return {
    isActive: true,
    isSort: false
  }
},
computed: {
  classArr: function () {
    return {
      active: this.isActive,
      sort:this.isSort
    }
  }
}

数组方法


单纯数组
:class="[isActive,isSort]"
data() {
  return{
    isActive:'active',
    isSort:'sort'
 }
}

数组与三元运算符结合判断选择需要的class


(注意:三元运算符后面的“:”两边的class需要加上单引号,否则不能正确渲染)
:class="[isActive?'active':'']"

:class="[isActive==1?'active':'']"

:class="[isActive==index?'active':'']"

:class="[isActive==index?'active':'otherActiveClass']"

数组对象结合动态判断

//前面这个active在对象里面可以不加单引号,后面这个sort要加单引号
:class="[{ active: isActive }, 'sort']"

:class="[{ active: isActive==1 }, 'sort']"

:class="[{ active: isActive==index }, 'sort']"
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3中,可以使用动态绑定class方式有多种。其中一种是使用对象语法。你可以通过在:class属性中传入一个对象来动态切换class。例如,你可以在模板中使用以下代码来实现动态绑定class: ```html <div :class="{'active': isActive, 'fw6': isA}"></div> ``` 在这个例子中,isActive和isA是在Vue实例的data中定义的变量。当isActive为true时,该元素将具有active类;当isA为true时,该元素将具有fw6类。你可以根据需要添加或删除其他类。 另一种方式是使用数组语法。你可以在:class属性中传入一个数组,数组中的每个元素都是一个类名。例如: ```html <div :class="\[isActive ? 'active' : '', isA ? 'fw6' : ''\]"></div> ``` 在这个例子中,如果isActive为true,则元素将具有active类;如果isA为true,则元素将具有fw6类。如果变量的值为false,则对应的类名将被省略。 这些是Vue3中动态绑定class的两种常见方式。你可以根据自己的需求选择适合的方式来实现动态绑定class。 #### 引用[.reference_title] - *1* [初识Vue 3.0 —— 动态class绑定](https://blog.csdn.net/qq_38499671/article/details/111994341)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [vue动态绑定class几种方法](https://blog.csdn.net/u013994400/article/details/125432141)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值