[英]bind to click event to external content when using innerHTML angular
[英]How to bind a click event/function in innerHTML Angular 2?
我有一个innerHTML如下:
getWidgetItem(widgetId: any) {
this._widgetId = widgetId;
this.widgets = [{'name': 'Welcome'}, {'name': 'Welcome1'}, {'name': 'Welcome2'}];
this.newArray = this.widgets.map((obj) => {
let htmlText = `
<div>
<section class="page subpage dashboard dashboard-page" style="overflow-y:hidden;">
<div class="newDashbaord">
<header>
<div class="actions">
<button class="control-btn borderless close-btn">
<span #target class="icon-close action-icon" (click)="RemoveWidget(${obj})"></span>
</button>
</div>
<h1 class="table-heading">${obj.name}</h1>
</header>
<main>
</main>
</div>
</section>
</div>`;
return htmlText;
});
}
但是问题是,我无法从我的范围访问click事件。
我有一个函数调用,如下所示:
private RemoveWidget(widget:any) {
if (typeof widget != 'undefined' && typeof this.widgets != 'undefined'){
console.log('CALLEDe', widget);
let index: number = this.widgets.indexOf(widget);
if (index !== -1) {
this.widgets.splice(index, 1);
}
}
}
我试过了:
ngAfterContentInit(): void {
// console.log('target called', this.elementRef.nativeElement.querySelector('span'));
this.renderer.listen(this.elementRef.nativeElement, 'click', (event) => {
console.log('event called??', event);
// this.RemoveWidget(event);
});
}
但是正在从我的templateUrl获取范围。 无法访问我的innerHTML范围中的范围。 我该如何访问?
您确实应该使用angular的模板引擎。
无需尝试通过脚本添加html,您只需使用*ngFor
HTML中使用以下代码即可实现所需的结果。
some-file.html
<div *ngFor="let widget of widgets">
<section class="page subpage dashboard dashboard-page" style="overflow-y:hidden;">
<div class="newDashbaord">
<header>
<div class="actions">
<button class="control-btn borderless close-btn">
<span #target class="icon-close action-icon" (click)="RemoveWidget(widget)"></span>
</button>
</div>
<h1 class="table-heading">widget.name</h1>
</header>
<main>
</main>
</div>
</section>
</div>
NgFor指令从可迭代对象的每个项目实例化一次模板。 每个实例化模板的上下文都从外部上下文继承,并且给定循环变量设置为可迭代对象中的当前项。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.