点击事件无法动态生成HTML角度2

当http.get方法更新我时,我正在创建表行…接收数据我使用角度2版本中的JS / jquery创建表行.

我的代码

<tr>
    <td>2</td>
    <td>BAJAJ-AUTO</td>
    <td>14.284%</td>
    <td>27/12/2013 12:00 am</td>
    <td>30/12/2013 12:00 am</td>
    <td>1935</td>
    <td>30/12/2013 12:00 am</td>
    <td>1935</td>
    <td>31/12/2013 12:00 am</td>
    <td>2120</td>
    <td><button class="btn btn-default" onclick="processAdvise('BAJAJ-AUTO')">Process Advise</button></td>
</tr>

所以最后一个td – 有一个按钮,它将调用我的角度2函数来处理它 – 这个代码甚至在功能开始时都没有到达

我也试过这个无济于事:

>(单击)角度2
> onclick并使用相同的HTML模板保存该功能
脚本标记

解决方法

Angular2不以任何方式处理组件模板之外的HTML,因此预期(click)=“processAdvise(‘BAJAJ-AUTO’)不起作用.

onclick =“processAdvise(‘BAJAJ-AUTO’)”当processAdvise()是Angular2组件的方法时也不起作用,因为onclick是纯HTML的,并且在全局JS范围内搜索以这种方式分配的函数而不是组件内部类.

<脚本>标签将从Angular2模板中删除

@Component({
  selector: '...',....
})
class MyComponent {
  constructor(private elRef:ElementRef) {
  }

  addHtml() {
    // add the HTML to the DOM
    this.elRef.nativeElement.querySelector('button').addEventListener('click',(event) => this.handleClick(event));
  }

  handleClick(event) {
    // doSomething();
  }
}

相关文章

vue阻止冒泡事件 阻止点击事件的执行 &lt;div @click=&a...
尝试过使用网友说的API接口获取 找到的都是失效了 暂时就使用...
后台我拿的数据是这样的格式: [ {id:1 , parentId: 0, name:...
JAVA下载文件防重复点击,防止多次下载请求,Cookie方式快速简...
Mip是什么意思以及作用有哪些