私はいくつかのデータにアクセスできます:
{{ content['term_goes_here'] }}
...そして、これはtrue
またはfalse
のいずれかに評価されました。次のように、式の真実性に応じてクラスを追加します。
<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 docs で推奨されているものです。
問題はブレードです、これを試してください
<i class="fa" v-bind:class="['{{content['cravings']}}' ? 'fa-checkbox-marked' : 'fa-checkbox-blank-outline']"></i>