Vue动态绑定Class常用的几种方式

第一种:基础用法

Html部分:

<div :class="active">基本用法</div>

Js部分:

data() {

        return {

                active: 'active'

        }

}

 

第二种:三元运算绑定单个 / 数组形式绑定多个Class

Html部分:

<div :class="isBind ? 'active' : ''">三元运算</div>
<div :class="[isBind ? 'active' : '', active]">使用数组</div>

Js部分:

data() {

        return {

                isBind: false,

                active: 'active'

        }

}

 

第三种:计算属性绑定单个或多个Class

Html部分:

<div :class="classObject">使用计算属性</div>

Js部分: 

data() {

        return {

                active: 'active',

                finishData: '2022-10-18 00:00:00'

        }

},

computed: {

        classObject() {

                return {

                        active: this.isBind,

                        'red-color': this.finishData != ''

                }

        }

}

 

第四种:使用函数绑定Class

Html部分:可自定义传参

div :class="bindClass(currDate,finishData)">函数绑定</div> 

Js部分:可处理复杂逻辑

data() {

        return {

                currDate: '2022-10-20 00:00:00',

                finishData: '2022-10-18 00:00:00'

        }

},

methods: {

        // 动态绑定Class

        bindClass(currDate,finishData){

                let classInfo = { redColor: false, active: true }

                if(new Date(finishData).getTime() > new Date(currDate).getTime()){

                        classInfo.redColor = true

                }

                return classInfo

        }

}

  • 5
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
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 ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值