【发布时间】:2017-01-09 11:54:25
【问题描述】:
我已经通过http.get() 方法加载了HTML 页面,并将此页面的内容添加到 div 标签中。
getRequestToAssignPage (param: string) : any {
return this.$http.get(param)
.map((res: Response) => {
this.status = res;
return res.text();
})
.toPromise()
.then(response => {
let restr: string = response;
restr = restr.replace(/(<head[^>]*)(?:[^])*?\/head>/ig, '')
.replace(/(<(\/?)body([^>]*?)>)/g, '')
.replace(/(<style[^>]*)(?:[^])*?\/style>/g, '')
.replace(/(<(\/?)html([^>]*?)>)/g, '')
.replace(/(<app-root[^>]*)(?:[^])*?\/app-root>/ig, '')
.replace(/(<\?[\s\S]*?\?>)|(<!DOCTYPE\s+\w+\s+\[[\s\S]*?\]>)|(<!\w[\s\S]*?>)/g, '')
.replace(/(href\s*=\s*(?:"))/ig, 'href="/#')
.replace(/(href\s*=\s*(?:'))/ig, "href='/#");
this.response = restr;
})
.catch(error => this.status = error );
}
你怎么看,这个方法,把response放到变量里,用正则表达式解析字符串 好的,接下来我把它添加到div中,像这样
<div [innerHTML]="response | safe"></div>
好的,我的页面正在显示。但是,脚本不起作用。它们存在于 div 标签中,但不执行。
我曾尝试使用 eval() 这样做,但结果很糟糕
let scripts: string[] = restr.match(/\<scr[\s\S]*?ipt>/g);
this.srcfield.nativeElement.innerHTML = '';
scripts.forEach((value, index) => {
eval.call(null, (this.srcfield.nativeElement.innerHTML = value));
});
SyntaxError: Unexpected token
为什么innerHTML 不执行加载的脚本标签?我该如何解决?
【问题讨论】:
标签: javascript http angular