Vue.js:条件类样式

Jer*_*mas 39 javascript conditional-formatting vue.js vuejs2

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

{{ content['term_goes_here'] }}
Run Code Online (Sandbox Code Playgroud)

......并且评估为true或者false.我想根据表达式的真实性添加一个类,如下所示:

<i class="fa" v-bind:class="[{{content['cravings']}} ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline']"></i>
Run Code Online (Sandbox Code Playgroud)

这里true给我的阶级fa-checkbox-marked和假会给我fa-checkbox-blank-outline.我上面写的方式给了我一个错误:

- invalid expression: v-bind:class="[{{content['cravings']}} ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline']"
Run Code Online (Sandbox Code Playgroud)

我该怎么写它才能有条件地确定课程?

Ber*_*ert 63

使用对象语法.

v-bind:class="{'fa-checkbox-marked': content['cravings'],  'fa-checkbox-blank-outline': !content['cravings']}"
Run Code Online (Sandbox Code Playgroud)

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

v-bind:class="getClass()"

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

最后,您可以将此工作用于此类任何内容属性.

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

methods:{
  getClass(property){
    return {
      'fa-checkbox-marked': this.content[property],
      'fa-checkbox-blank-outline': !this.content[property]
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

  • 我重构为:`&lt;i class="fa" :class="[{ 'fa-checkbox-marked': content['cravings'] }, 'fa-checkbox-blank-outline']"&gt;&lt;/i&gt; ` (3认同)

Hap*_*wan 22

<i class="fa" v-bind:class="cravings"></i>
Run Code Online (Sandbox Code Playgroud)

并添加计算:

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

  • 投票支持计算机,它比在html标签中使用表达式更清晰. (3认同)
  • 我将不得不使用太多的方法,因为大约有20个不同的术语 (2认同)

kal*_*azy 12

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

<div v-bind:class="{ disabled: order.cancelled_at }"></div>
Run Code Online (Sandbox Code Playgroud)

这是Vue文档推荐的内容.


Bou*_*him 12

您可以使用如下所示的带有反引号 `` 的字符串模板:

:class="`${content['cravings'] ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline'}`"
Run Code Online (Sandbox Code Playgroud)


小智 7

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

html

 <div class="Main" v-bind:class="{ Sub: page}"  >
Run Code Online (Sandbox Code Playgroud)

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

js

data:{
page : true;
}
Run Code Online (Sandbox Code Playgroud)

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


Jul*_*gro 5

问题是刀片,请尝试此

<i class="fa" v-bind:class="['{{content['cravings']}}' ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline']"></i>
Run Code Online (Sandbox Code Playgroud)