繁体   English   中英

Vue.js:条件类样式绑定

[英]Vue.js: Conditional class style binding

我有一些数据可以通过以下方式访问:

{{ content['term_goes_here'] }}

...这被评估为truefalse 我想根据表达式的真实性添加一个类,如下所示:

<i class="fa" v-bind:class="[{{content['cravings']}} ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline']"></i>

其中true给我类fa-checkbox-marked和 false 会给我fa-checkbox-blank-outline 我上面写的方式给了我一个错误:

- invalid expression: v-bind:class="[{{content['cravings']}} ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline']"

我应该如何编写它才能有条件地确定班级?

使用对象语法

v-bind:class="{'fa-checkbox-marked': content['cravings'],  'fa-checkbox-blank-outline': !content['cravings']}"

当对象变得更复杂时,将其提取到方法中。

v-bind:class="getClass()"

methods:{
    getClass(){
        return {
            'fa-checkbox-marked': this.content['cravings'],  
            'fa-checkbox-blank-outline': !this.content['cravings']}
    }
}

最后,您可以使这项工作适用于像这样的任何内容属性。

v-bind:class="getClass('cravings')"

methods:{
  getClass(property){
    return {
      'fa-checkbox-marked': this.content[property],
      'fa-checkbox-blank-outline': !this.content[property]
    }
  }
}
<i class="fa" v-bind:class="cravings"></i>

并添加计算:

computed: {
    cravings: function() {
        return this.content['cravings'] ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline';
    }
}

为什么不将对象传递给 v-bind:class 以动态切换类:

<div v-bind:class="{ disabled: order.cancelled_at }"></div>

这是Vue 文档所推荐的。

问题是刀片,试试这个

<i class="fa" v-bind:class="['{{content['cravings']}}' ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline']"></i>

如果您想在Vue.js中为具有条件的相同元素应用单独的 css 类,您可以使用下面给定的方法。它在我的场景中有效。

html

 <div class="Main" v-bind:class="{ Sub: page}"  >

在这里, MainSub是同一个 div 元素的两个不同的类名。 v-bind:class指令用于在此处绑定子类。 page是我们用来在值更改时更新类的属性。

js

data:{
page : true;
}

如果需要,我们可以在这里应用条件。 因此,如果页面属性变为 true 元素将采用MainSub类 css 样式。 但如果为 false,则仅应用Main类 css 样式。

您可以使用字符串模板,如反引号 `` :

:class="`${content['cravings'] ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline'}`"

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM