javascript – angular2:包括组件中的第三方js脚本

参见英文答案 > script tag in angular2 template / hook when template dom is loaded2个
有没有办法在Angular2组件中包含第三方JS脚本而不是将其包含在index.html中?

我有一个包装dataTables的表组件.它是唯一需要dataTables js / css包含的组件.如果我可以让我的index.html更清洁,那就太好了.组件装饰器允许您指定css文件.

我尝试在我的组件html中移动我的脚本标签,但这似乎不起作用.

解决方法

组件模板中的脚本标记将被删除.解决方法是在ngAfterViewInit()中动态创建脚本标记

另见https://github.com/angular/angular/issues/4903

import { DOCUMENT } from '@angular/common';
...

constructor(private @Inject(DOCUMENT) document,private elementRef:ElementRef) {};

ngAfterViewInit() {
  var s = this.document.createElement("script");
  s.type = "text/javascript";
  s.src = "http://somedomain.com/somescript";
  this.elementRef.nativeElement.appendChild(s);
}

另见https://stackoverflow.com/a/9413803/217408

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...