我的代码在下面,我想在完成折叠和展开时上下改变图标。但不知怎的,它不起作用。
<div class="attach-link">
<a href="javascript:void(0);" *ngIf="fileData.fileDataType.canAttach && !isFinancialEntity" (click)="openFileInput(i)">
<i class="fa fa-plus"></i> Add Attachment</a>
<input type="file" class="hide" id="fileData_{{i}}" ng2FileSelect [uploader]="fileData.uploader" (onFileSelected)="onFileSelected()"
/>
<a class="attachFileList" href="#attachFileList_{{i}}" data-toggle="collapse">
<i class="fa fa-angle-up" ></i>
Attachments [{{fileData.fileList.length}}] </a>
</div>
并添加了脚本:
$('a[data-toggle="collapse"]').click(function () {
//$(this).find('i').addClass('fa fa-angle-up').removeClass('fa fa-angle-down');
$(this).find('i .fa fa-angle-up').toggleClass('fa fa-angle-down');
});
我不知道问题是什么。任何帮助将不胜感激。非常感谢。
答案 0 :(得分:3)
以下是以角度向上和向下折叠的示例代码。
<div class="attach-link">
<a href="javascript:void(0);" (click)="openFileInput(i)">
<i class="fa fa-plus"></i> Add Attachment</a>
<input type="file" class="hide" id="fileData_{{i}}" ng2FileSelect (onFileSelected)="onFileSelected()"
/>
<br>
<a (click)="collapse=!collapse" class="attachFileList" href="#attachFileList_{{i}}" data-toggle="collapse">
<i class="fa" [ngClass]="{'fa-angle-up': collapse, 'fa-angle-down': !collapse}"></i>
Attachments {{fileData.fileList.length}}
</a>
</div>
控制器
import { Component } from '@angular/core';
@Component({
selector: 'my-app',
templateUrl: './app.component.html',
styleUrls: [ './app.component.css' ]
})
export class AppComponent {
name = 'Angular 5';
collapse:boolean =true;
}
答案 1 :(得分:0)
在@ sharma-vikram答案中,如果有人想解决上述解释的扩展折叠问题,请在一个循环中再添加一个元素,可以按以下步骤进行操作。 观察:这是一个简单的解决方案,不使用ngbCollapse或材质。
模板(html):
...
<div *ngFor="let item of items">
<div class="row">
<div class="col" (click)="toggle(rowItem)" >
<i class="fa" [ngClass]="{'fa-plus': valores.classList.contains('d-none'), 'fa-minus': !valores.classList.contains('d-none')}"></i>
</div>
</div>
<div class="row" #rowItem>
Value
</div>
</div>
控制器(ts):
...
public toggle( element: HTMLElement) {
element.classList.toggle('d-none');
}