Angolare: classe condizionale con * ngClass


562

Cosa c'è di sbagliato nel mio codice angolare? Ricevo:

Cannot read property 'remove' of undefined at BrowserDomAdapter.removeClass ...

HTML

<ol class="breadcrumb">
    <li *ngClass="{active: step==='step1'}" (click)="step='step1; '">Step1</li>
    <li *ngClass="{active: step==='step2'}"  (click)="step='step2'">Step2</li>
    <li *ngClass="{active: step==='step3'}" (click)="step='step3'">Step3</li>
</ol>

Risposte:


1230

La versione angolare 2, ..., 9 offre diversi modi per aggiungere le classi in modo condizionale:

digita uno

[class.my-class]="step === 'step1'"

digitare due

[ngClass]="{'my-class': step === 'step1'}"

e opzione multipla:

[ngClass]="{'my-class': step === 'step1', 'my-class2':step === 'step2' }"

tipo tre

[ngClass]="{1:'my-class1',2:'my-class2',3:'my-class4'}[step]"

digitare quattro

[ngClass]="(step=='step1')?'my-class1':'my-class2'"

7
Risposta perfetta, basta correggere il tipo 2 su: [ngClass] = "{'my-class': step == 'step1'}" Con '' int il nome della classe
Adriano Galesso Alves

2
Per il tipo tre, l'ordine del nome della classe e il controllo sono errati. Dovrebbe essere prima il nome della classe come [ngClass] = "{'my-class1': 1, 'my-class2': 2}"
obaylis,

1
sembra che "tipo tre" e "tipo quattro" siano usi specifici di [ngClass]="js expression returning html class string"così che sono gli stessi in questo senso
YakovL

1
Grazie amico .. sei fantastico
Pranav MS

1
Risposta perfetta amico. Grazie mille !
Anjana Silva,

423

[ngClass]=...invece di *ngClass.

* è solo per la sintassi abbreviata per direttive strutturali in cui è possibile ad esempio utilizzare

<div *ngFor="let item of items">{{item}}</div>

invece della versione equivalente più lunga

<template ngFor let-item [ngForOf]="items">
  <div>{{item}}</div>
</template>

Vedi anche https://angular.io/docs/ts/latest/api/common/index/NgClass-directive.html

<some-element [ngClass]="'first second'">...</some-element>
<some-element [ngClass]="['first', 'second']">...</some-element>
<some-element [ngClass]="{'first': true, 'second': true, 'third': false}">...</some-element>
<some-element [ngClass]="stringExp|arrayExp|objExp">...</some-element>
<some-element [ngClass]="{'class1 class2 class3' : true}">...</some-element>

Vedi anche https://angular.io/docs/ts/latest/guide/template-syntax.html

<!-- toggle the "special" class on/off with a property -->
<div [class.special]="isSpecial">The class binding is special</div>

<!-- binding to `class.special` trumps the class attribute -->
<div class="special"
     [class.special]="!isSpecial">This one is not so special</div>
<!-- reset/override all class names with a binding  -->
<div class="bad curly special"
     [class]="badCurly">Bad curly</div>

1
Dalla documentazione angolare: "L'asterisco è" zucchero sintattico "per qualcosa di un po 'più complicato. Internamente, Angular traduce l'attributo * ngIf in un elemento <ng-template>, avvolto attorno all'elemento host, in questo modo. La direttiva * ngIf spostato nell'elemento <ng-template> dove è diventato un'associazione di proprietà, [ngIf]. Il resto dell'elemento <div>, incluso l'attributo class, si è spostato all'interno dell'elemento <ng-template>. " - maggiori informazioni @ angular.io/guide/structural-directives#the-asterisk--prefix
Combina

In realtà, non è niente di più complicato, *consente solo una sinossi semplificata anziché una forma cannonica.
Günter Zöchbauer,

76

Un'altra soluzione sarebbe usare [class.active].

Esempio :

<ol class="breadcrumb">
    <li [class.active]="step=='step1'" (click)="step='step1'">Step1</li>
</ol>

8
Penso che questa dovrebbe essere la risposta accettata in quanto questo è il modo Angular2 per impostare la classe html (di cui non sapevo e Google mi ha portato qui).
kub1x,

62

Questa è la struttura normale per ngClassè:

[ngClass]="{'classname' : condition}"

Quindi nel tuo caso, basta usarlo in questo modo ...

<ol class="breadcrumb">
  <li [ngClass]="{'active': step==='step1'}" (click)="step='step1'">Step1</li>
  <li [ngClass]="{'active': step==='step2'}" (click)="step='step2'">Step2</li>
  <li [ngClass]="{'active': step==='step3'}" (click)="step='step3'">Step3</li>
</ol>

48

con i seguenti esempi è possibile utilizzare "SE ELSE"

<p class="{{condition ? 'checkedClass' : 'uncheckedClass'}}">
<p [ngClass]="condition ? 'checkedClass' : 'uncheckedClass'">
<p [ngClass]="[condition ? 'checkedClass' : 'uncheckedClass']">

1
Ho provato la prima e la seconda soluzione. Solo il secondo ha funzionato per me
user1238784

36

È possibile utilizzare ngClass per applicare il nome della classe sia in modo condizionale che non in Angolare

Per esempio

[ngClass]="'someClass'">

Condizionale

[ngClass]="{'someClass': property1.isValid}">

Condizione multipla

 [ngClass]="{'someClass': property1.isValid && property2.isValid}">

Espressione del metodo

[ngClass]="getSomeClass()"

Questo metodo sarà all'interno del tuo componente

 getSomeClass(){
        const isValid=this.property1 && this.property2;
        return {someClass1:isValid , someClass2:isValid};
    }

14

Dovresti usare qualcosa ( [ngClass]anziché *ngClass) come quello:

<ol class="breadcrumb">
  <li [ngClass]="{active: step==='step1'}" (click)="step='step1; '">Step1</li>
  (...)


10

In Angular 7.X

Le classi CSS vengono aggiornate come segue, a seconda del tipo di valutazione dell'espressione:

  • stringa - vengono aggiunte le classi CSS elencate nella stringa (delimitato da spazi)

  • Array: vengono aggiunte le classi CSS dichiarate come elementi Array

  • Le chiavi oggetto sono classi CSS che vengono aggiunte quando l'espressione fornita nel valore restituisce un valore di verità, altrimenti vengono rimosse.

<some-element [ngClass]="'first second'">...</some-element>

<some-element [ngClass]="['first', 'second']">...</some-element>

<some-element [ngClass]="{'first': true, 'second': true, 'third': false}">...</some-element>

<some-element [ngClass]="stringExp|arrayExp|objExp">...</some-element>

<some-element [ngClass]="{'class1 class2 class3' : true}">...</some-element>

7

per estendere MostafaMashayekhi la sua risposta per l'opzione due> puoi anche concatenare più opzioni con un ','

[ngClass]="{'my-class': step=='step1', 'my-class2':step=='step2' }"

Inoltre * ngIf può essere utilizzato in alcune di queste situazioni, in genere combinato con un * ngFor

class="mats p" *ngIf="mat=='painted'"

6

Mentre stavo creando un modulo reattivo, ho dovuto assegnare 2 tipi di classe sul pulsante. Ecco come l'ho fatto:

<button type="submit" class="btn" [ngClass]="(formGroup.valid)?'btn-info':''" 
[disabled]="!formGroup.valid">Sign in</button>

Quando il modulo è valido, il pulsante ha classe btn e btn (da bootstrap), altrimenti solo classe btn.


5

Inoltre, puoi aggiungere con la funzione metodo:

In HTML

<div [ngClass]="setClasses()">...</div>

In component.ts

// Set Dynamic Classes
  setClasses() {
    let classes = {
      constantClass: true,
      'conditional-class': this.item.id === 1
    }

    return classes;
  }

4

Lascia che YourCondition sia la tua condizione o una proprietà booleana, quindi fai così

[class.yourClass]="YourCondition"

4

ngClass sintassi:

[ngClass]="{'classname' : conditionFlag}"

Puoi usare così:

<ol class="breadcrumb">
  <li [ngClass]="{'active': step==='step1'}" (click)="step='step1'">Step1</li>
  <li [ngClass]="{'active': step==='step2'}" (click)="step='step2'">Step2</li>
  <li [ngClass]="{'active': step==='step3'}" (click)="step='step3'">Step3</li>
</ol>

4

Questo è ciò che ha funzionato per me:

[ngClass]="{'active': dashboardComponent.selected_menu == 'profile'}"

4

Puoi usare [ngClass] o [class.classname], entrambi funzioneranno allo stesso modo.
[class.my-class]="step==='step1'"

   O

[ngClass]="{'my-class': step=='step1'}"

Entrambi funzioneranno allo stesso modo!


1

Non pertinente con la [ngClass]direttiva, ma ho riscontrato anche lo stesso errore

Impossibile leggere la proprietà 'remove' di undefined in ...

e ho pensato di essere l'errore nella mia [ngClass]condizione, ma si è scoperto che la proprietà a cui stavo tentando di accedere nella condizione di [ngClass]non è stata inizializzata.

Come se avessi questo nel mio file dattiloscritto

element: {type: string};

e nel mio [ngClass]stavo usando

[ngClass]="{'active', element.type === 'active'}"

e stavo ottenendo l'errore

Impossibile leggere la proprietà 'tipo' di undefined in ...

e la soluzione era riparare la mia proprietà a

element: {type: string} = {type: 'active'};

Spero che aiuti qualcuno che sta cercando di abbinare una condizione di una proprietà in [ngClass]


1

<div class="collapse in " [ngClass]="(active_tab=='assignservice' || active_tab=='manage')?'show':''" id="collapseExampleOrganization" aria-expanded="true" style="">
 <ul> 	 <li class="nav-item" [ngClass]="{'active': active_tab=='manage'}">
<a routerLink="/main/organization/manage" (click)="activemenu('manage')"> <i class="la la-building-o"></i>
<p>Manage</p></a></li> 
<li class="nav-item" [ngClass]="{'active': active_tab=='assignservice'}"><a routerLink="/main/organization/assignservice" (click)="activemenu('assignservice')"><i class="la la-user"></i><p>Add organization</p></a></li>
</ul></div>

Il codice è un buon esempio di ngClass se altrimenti condizione.

[ngClass]="(active_tab=='assignservice' || active_tab=='manage')?'show':''"

[ngClass]="{'active': active_tab=='assignservice'}"

0

Prova così ..

Definisci la tua classe con ''

<ol class="breadcrumb">
    <li *ngClass="{'active': step==='step1'}" (click)="step='step1; '">Step1</li>
    <li *ngClass="{'active': step==='step2'}"  (click)="step='step2'">Step2</li>
    <li *ngClass="{'active': step==='step3'}" (click)="step='step3'">Step3</li>
</ol>
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.