通过以下链接后
我知道我们不应该直接操纵DOM.因此,我开始探索使用角度4的Renderer2.
因此,我开始编写一些代码以将svg添加到DOM.以下是我的代码片段.
<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中,但未显示在网页中.
任何帮助将非常感激.
解决方法:
this.renderer.createElement(‘svg’)创建HTML元素而不是SVGElement,因为Angular不知道您想要svg:svg.
尝试使用this.renderer.createElement(‘svg’,’svg’),其中第二个参数是命名空间.每个svg元素必须以相同的方式创建,例如:
let rect = this.renderer.createElement('rect', 'svg')
this.renderer.appendChild(svg, rect)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。