如何在角度2中仅将一个HTML元素添加到一个HTML元素

时间:2017-03-20 11:49:47

标签: angular ng-class

我的JSON数据看起来像这样。

let manageDiscRecords: discRecords[] = [
    {
    "ID"                  : 3,
    "discRec"             : "Some sample record",
    "Tasks"               : [{
                            "ID"          : 7,
                            "discParcel"  : ["string1", "string2"]
                            }]
    }, 
    {
    "ID"                  : 4,
    "discRec"             : "Some sample record 2",
    "Tasks"               : [{
                            "ID"          : 8,
                            "discParcel"  : ["string3", "string4"]
                            }]
    }
];

我的HTML代码是:

<li *ngFor="let parcel of discRecords; let i= index">
                    <a href="#" #elem id="availRecord_{{i}}" (click)="getDisplay(elem.id)">
                        {{ parcel.discRec}} 
                    </a>
                        <ul style="list-style: none; display: none;" id="subRecordHolder_{{i}}">

                            <li *ngFor="let task of parcel.Tasks; let i= index" [className]="itemAdded">
                                <ul style="list-style: none; padding-left:0">

                                   <li *ngFor="let discParcel of task.discParcel;  let i= index">  
                                       <a href="#" #elem id="availSubRecords_{{parcel.ID}}_{{task.ID}}_{{i}}" (click)="getStyle(elem.id, discParcel)">
                                           {{ discParcel}}
                                        </a>
                                    </li>

                                </ul>
                            </li>
                        </ul>
                    </li>

我的输出看起来像这样。

Some sample record
 - string 1 
 - string 2

some sample record 2
 - string 4
 - string 3

现在,我想点击时将类名“clickedNow”应用于“string 1”元素。你能告诉我如何实现这个目标。

2 个答案:

答案 0 :(得分:2)

这样的事情应该这样做:

在你的模板中:

<li *ngFor="let discParcel of task.discParcel;  let i= index" [ngClass]="{'clickedNow' : discParcel === clickedElement}" (click)="elementActive(discParcel)">  
  <a href="#" #elem id="availSubRecords_{{parcel.ID}}_{{task.ID}}_{{i}}" (click)="getStyle(elem.id, discParcel)">
    {{ discParcel}}
  </a>
</li>

在您的组件中:

let clickedElement : string = '';

elementActive(elem){
 this.clickedElement = elem; 
}

答案 1 :(得分:0)

这样做

<li [ngClass]="{'clickedNow' : clickedElement}" (click)="elementActive(elem)">
  {{discParcel}}
<li>

private clickedElement: boolean = false
elementActive(elem){
    if(elem == "string1")
        this.clickedElement = elem; 
}