Açısal: * ngClass ile koşullu sınıf


562

Açısal kodumda sorun nedir? Alıyorum:

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>

Yanıtlar:


1227

Açısal sürüm 2, ..., 9 sınıfları koşullu olarak eklemenin çeşitli yollarını sunar:

bir tane yaz

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

iki tür

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

ve çoklu seçenek:

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

üç tip

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

dört tane yaz

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

7
Mükemmel cevap, sadece 2 tipini şu şekilde düzeltin: [ngClass] = "{'my-class': step == 'step1'}" '' int sınıf adıyla
Adriano Galesso Alves 28:17

2
Üçüncü tür için sınıf adı ve denetimi sırası yanlıştır. İlk önce [ngClass] = "{'my-class1': 1, 'my-class2': 2}" gibi sınıf adı olmalıdır
obaylis

1
"tip üç" ve "tip dört", [ngClass]="js expression returning html class string"bu anlamda aynı olan belirli kullanımlardır
YakovL

1
Teşekkürler adamım ...
Harikasın

1
Mükemmel cevap arkadaşı. Çok teşekkürler !
Anjana Silva

422

[ngClass]=...yerine *ngClass.

* yalnızca yapısal yönergeler için kısayol sözdizimi içindir.

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

daha uzun eşdeğer versiyon yerine

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

Ayrıca bkz. 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>

Ayrıca bkz. 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
Açısal dokümantasyondan: "Yıldız işareti biraz daha karmaşık bir şey için" sözdizimsel şekerdir ". Angular, Angular, * ngIf niteliğini, ana öğe elemanının etrafına sarılan bir <ng-template> öğesine çevirir. * NgIf yönergesi <ng-template> öğesine taşındı ve burada [ngIf] özellik bağlama oldu. <div> öğesinin geri kalanı <ng-template> öğesinin içine taşındı. - daha fazla bilgi @ angular.io/guide/structural-directives#the-asterisk--prefix
birleştirin

Aslında, daha karmaşık bir şey değil, *sadece topçu formu yerine basitleştirilmiş bir sinax sağlar.
Günter Zöchbauer

75

Başka bir çözüm kullanmak olurdu [class.active].

Misal :

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

8
Bu html sınıfını ayarlamak için Angular2 yolu olduğu gibi bu kabul edilen cevap olmalıdır düşünüyorum (bilmiyordum ve google beni buraya getirdi).
kub1x

62

Bunun için normal yapı ngClassşudur:

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

Yani sizin durumunuzda, sadece böyle kullanın ...

<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

aşağıdaki örneklerle 'ELSE IF' kullanabilirsiniz

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

1
Birinci ve ikinci çözümü denedim. Sadece ikincisi benim için çalıştı
user1238784

36

NgClass'ı sınıf adını Angular'da değil koşullu olarak uygulamak için kullanabilirsiniz

Örneğin

[ngClass]="'someClass'">

şartlı

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

Çoklu Durum

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

Yöntem ifadesi

[ngClass]="getSomeClass()"

Bu yöntem bileşeninizin içinde olacaktır

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

14

Bunun [ngClass]yerine ( yerine *ngClass) bir şey kullanmalısınız :

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


10

İçinde Angular 7.X

CSS sınıfları, ifade değerlendirmesinin türüne bağlı olarak aşağıdaki gibi güncellenir:

  • string - dizede listelenen CSS sınıfları (boşlukla ayrılmış) eklenir

  • Dizi - Dizi öğeleri olarak bildirilen CSS sınıfları eklenir

  • Nesne anahtarları, değerde verilen ifade doğruluk değeri olarak değerlendirildiğinde eklenen CSS sınıflarıdır, aksi takdirde kaldırılırlar.

<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

MostafaMashayekhi'yi ikinci seçenek için cevabını genişletmek için> birden fazla seçeneği bir ','

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

Ayrıca * ngIf bu durumların bazılarında genellikle * ng

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

6

Reaktif bir form oluştururken, butona 2 tip sınıf atamak zorunda kaldım. Ben böyle yaptım:

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

Form geçerli olduğunda, düğmenin btn ve btn sınıfı (bootstrap'tan) vardır, aksi takdirde sadece btn sınıfı vardır.


5

Ayrıca, yöntem işlevi ile ekleyebilirsiniz:

HTML'de

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

Component.ts içinde

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

    return classes;
  }

4

Izin vermek, YourCondition sizin durumunuz veya bir boolean özellik, sonra bunu yapmak

[class.yourClass]="YourCondition"

4

ngClass sözdizimi:

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

Bunun gibi kullanabilirsiniz:

<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

Benim için işe yarayan buydu:

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

4

[NgClass] veya [class.classname] kullanabilirsiniz, her ikisi de aynı şekilde çalışır.
[class.my-class]="step==='step1'"

   VEYA

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

Her ikisi de aynı şekilde çalışacak!


1

[ngClass]Direktif ile ilgili değil , aynı zamanda aynı hatayı alıyordum

Undefined öğesinin 'remove' özelliği okunamıyor ...

ve benim durumumda hata olduğunu düşündüm [ngClass]ama bu durumda erişmeye çalıştım özelliği [ngClass]başlatılmadı ortaya çıktı.

Benim daktilo dosyamda olduğu gibi

element: {type: string};

ve bence [ngClass]kullanıyordum

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

ve hatayı alıyordum

Undefined öğesinin 'type' özelliği okunamıyor ...

ve çözüm, mülkümü

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

Umarım bir mülkün durumunu eşleştirmeye çalışan birine yardım eder. [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>

Kod, başka bir koşul varsa ngClass'ın iyi bir örneğidir.

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

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

0

Bu şekilde dene ..

Sınıfınızı '' ile tanımlayın

<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>
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.