2 回答
TA贡献2019条经验 获得超9个赞
尝试为 myLinkBody 数组中的每个对象设置一个新属性,以保持当前状态,无论其是否正在编辑。
myLinkBody.map(body => { body.currentState="edit"; return body});
并使用额外的标签输入字段使用[(ngModel)]。[hidden]在锚标签和输入标签上使用,根据当前状态显示和隐藏它们。
<span *ngFor="let body of myLinkBody;let last=last;let i=index" class="myLinkBody" [class.myLinkBodyLast]="last">
<a [href]="domainURL+body.href" [hidden]="body.currentState=='save'">{{body.value}}</a>
<input type="text" [(ngModel)]="myLinkBody[i].name" [hidden]="body.currentState=='save'"/>
<button (click)="edit($event,body,index)">{{body.currentState}}</button>
<div id="deleteLinkButton"></div>
</span>
在编辑功能中
edit(event,body,index){
if(body.state == 'save')
this.myLinkBody[index].state='edit';
else
this.myLinkBody[index].state='save';
.....your code here
}
示例 stackblitz :https://stackblitz.com/edit/angular-5hrmfv
TA贡献1900条经验 获得超5个赞
我已经实现了一个基本片段,它将使用 *ngFor 将示例数据显示为列表,其中可以通过单击编辑按钮来编辑字段。
查看此处的代码片段:https ://stackblitz.com/edit/angular-rmvkat
实时网址: https: //angular-rmvkat.stackblitz.io/
- 2 回答
- 0 关注
- 108 浏览
添加回答
举报