在查看以下链接后
我明白我们不应该直接操纵DOM。因此,我开始研究如何使用Angular 4的Renderer2。
于是我开始编写一些代码将svg添加到DOM中。以下是我的代码片段。
HTML代码
<div class="row">
<div class="col-12">
<div #myBarGraph id="host"></div>
</div>
</div>
Component.ts
export class BarGraphComponent implements OnInit {
host:any;
svg:any;
@ViewChild('myBarGraph') myBarGraph:ElementRef;
constructor(private renderer:Renderer2) { }
ngOnInit() {
//some logic
}
// called on some drop down selection
teamSelection(){
//some logic
this.host = this.mybarGraph.nativeElement;
buildSVG();
}
buildSVG():void {
this.svg = this.renderer.createElement('svg');
this.renderer.setAttribute(this.svg,'width','600');
this.renderer.setAttribute(this.svg,'height','400');
this.renderer.setAttribute(this.svg,'background-color','blue');
this.renderer.appendChild(this.host,this.svg);
}
}
上面的代码能够将svg元素添加到DOM中。但令我惊讶的是,它实际上没有显示出svg元素!
我确实参考了以下问题: 但目前为止还没有找到合适的答案。
以下是问题的截图 正如你在上面看到的,svg存在于DOM中,但它没有显示在网页中。任何帮助都将不胜感激。
nativeElement
公开的DOM中。 - lemmingworks