113 votes

Vue.js : Liaison conditionnelle de style de classe

J'ai des données qui sont accessibles via :

{{ content['term_goes_here'] }}

... et ceci évalué à soit true o false . J'aimerais ajouter une classe en fonction de la véracité de l'expression, comme suit :

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

true me donne la classe fa-checkbox-marked et faux me donnerait fa-checkbox-blank-outline . La façon dont je l'ai écrit ci-dessus me donne une erreur :

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

Comment dois-je l'écrire pour pouvoir déterminer conditionnellement la classe ?

2 votes

Vous pouvez aussi faire quelque chose comme <button :class="disabled && 'disabled'"> comme raccourci pour <button :class="disabled ? 'disabled' : false"> .

174voto

Bert Evans Points 2415

Utilisez le syntaxe des objets .

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

Lorsque l'objet devient plus compliqué, il faut l'extraire dans une méthode.

v-bind:class="getClass()"

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

Enfin, vous pourriez faire en sorte que cela fonctionne pour n'importe quelle propriété de contenu comme ceci.

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

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

5 votes

Je l'ai remanié : <i class="fa" :class="[{ 'fa-checkbox-marked': content['cravings'] }, 'fa-checkbox-blank-outline']"></i>

1 votes

@JeremyThomas Je choisirais soit la syntaxe des tableaux, soit celle des objets, mais probablement pas les deux.

0 votes

Oui, j'ai été un peu surpris de voir cette syntaxe mélangée dans leur documentation.

50voto

Happyful Points 2083
<i class="fa" v-bind:class="cravings"></i>

et ajouter en calculée :

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

3 votes

Je devrais avoir trop de méthodes car il y a environ 20 termes différents.

5 votes

Votez pour le calcul, c'est beaucoup plus propre que d'avoir des expressions à l'intérieur des balises html.

45voto

kaleazy Points 1129

Pourquoi ne pas passer un objet à v-bind:class pour basculer dynamiquement la classe :

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

C'est ce qui est recommandé par le Documentation sur Vue .

11voto

Le problème est une lame, essayez ceci

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

9voto

Boussadjra Brahim Points 12045

Vous pouvez utiliser un modèle de chaîne de caractères comme avec des backticks `` :

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

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X