首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Vue.js:条件类样式绑定

Vue.js:条件类样式绑定
EN

Stack Overflow用户
提问于 2017-04-04 14:45:09
回答 6查看 251.7K关注 0票数 107

我有一些可以通过以下途径获得的数据:

代码语言:javascript
运行
复制
{{ content['term_goes_here'] }}

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

代码语言:javascript
运行
复制
<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。我上面写它的方式给了我一个错误:

代码语言:javascript
运行
复制
- invalid expression: v-bind:class="[{{content['cravings']}} ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline']"

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

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2017-04-04 14:47:53

使用对象语法

代码语言:javascript
运行
复制
v-bind:class="{'fa-checkbox-marked': content['cravings'],  'fa-checkbox-blank-outline': !content['cravings']}"

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

代码语言:javascript
运行
复制
v-bind:class="getClass()"

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

最后,您可以对任何类似的内容属性执行此操作。

代码语言:javascript
运行
复制
v-bind:class="getClass('cravings')"

methods:{
  getClass(property){
    return {
      'fa-checkbox-marked': this.content[property],
      'fa-checkbox-blank-outline': !this.content[property]
    }
  }
}
票数 166
EN

Stack Overflow用户

发布于 2017-04-04 14:48:23

代码语言:javascript
运行
复制
<i class="fa" v-bind:class="cravings"></i>

并加上计算:

代码语言:javascript
运行
复制
computed: {
    cravings: function() {
        return this.content['cravings'] ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline';
    }
}
票数 46
EN

Stack Overflow用户

发布于 2018-07-09 00:13:23

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

代码语言:javascript
运行
复制
<div v-bind:class="{ disabled: order.cancelled_at }"></div>

这是Vue文档推荐的内容。

票数 42
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43210508

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档