【发布时间】:2018-05-08 20:06:41
【问题描述】:
通过以下链接后
我知道我们不应该直接操作 DOM。于是我开始探索使用 angular 4 的 Renderer2。
所以我开始编写一些代码来将 svg 添加到 DOM。以下是我的代码的 sn-ps。
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 元素!。
我确实参考了以下问题
- Angular2 Renderer: Svg rect is rendered but not showing in page
- Angular2 does not render SVG in runtime
但到目前为止我找不到正确的答案。
正如你在上面看到的,svg 存在于 DOM 中,但它不显示在网页中。 任何帮助将不胜感激。
【问题讨论】:
标签: javascript angular d3.js svg