AngularNGXChart在加载时未正确适应父容器大小
创始人
2024-10-28 18:31:17
0

使用ViewChild和ngAfterViewInit钩子对图表进行重新渲染。

在组件的HTML文件中,设置一个包含图表的div,并使用ngStyle指令将其大小设置为父级容器的大小:

在组件的TS文件中,使用ViewChild和ngAfterViewInit来获取父级容器的大小,并在重新渲染图表时将其应用于ngx-charts组件:

import { Component, ViewChild, ElementRef, AfterViewInit } from '@angular/core';
import { ChartComponent } from 'ng2-charts';

@Component({
  selector: 'app-my-chart',
  template: '
', styleUrls: ['./my-chart.component.css'] }) export class MyChartComponent implements AfterViewInit { @ViewChild('chartDiv') chartDiv: ElementRef; @ViewChild(ChartComponent) chartComponent: ChartComponent; public pieChartData: number[] = []; public pieChartLabels: string[] = []; public pieChartType = 'pie'; public pieChartOptions: any = { responsive: true }; parentHeight: string; parentWidth: string; ngAfterViewInit() { this.parentHeight = this.chartDiv.nativeElement.parentElement.offsetHeight + 'px'; this.parentWidth = this.chartDiv.nativeElement.parentElement.offsetWidth + 'px'; this.chartComponent.chart.update(); } }

该示例组件显示了一个饼图,将其大小设置为其父级容器的大小。在ngAfterViewInit钩子中,我们使用ViewChild获取chartDiv元素的引用,并使用nativeElement获取其父元素的高度和宽度。然后,我们更新ChartComponent的图表,并在这之后重新渲染。

相关内容

热门资讯

透视有挂!hhpoker软件安... 透视有挂!hhpoker软件安装包(透视)哈糖大菠萝攻略,教程策略(有挂教学)-哔哩哔哩1、下载好h...
德普之星辅助工具如何打开!哈糖... 德普之星辅助工具如何打开!哈糖大菠萝有挂吗(透视)神器-其实必备存在有挂1、在德普之星辅助工具如何打...
透视解迷!聚星ai辅助工具下载... 透视解迷!聚星ai辅助工具下载(透视)wepoker怎么设置透视,教程方针(有挂秘笈)-哔哩哔哩1....
wepoker破解器激活码!w... wepoker破解器激活码!wepoker免费透视脚本(透视)器-其实揭露真的有挂1、wepoker...
模拟器打开hhpoker!po... 模拟器打开hhpoker!pokemmo辅助官网(透视)软件-原来总结有挂1、该软件可以轻松地帮助玩...
透视了解!wpk俱乐部怎么透视... 透视了解!wpk俱乐部怎么透视(透视)hhpoker真的假的,教程资料(有挂讲解)-哔哩哔哩1、进入...
wepoker私局辅助!wpk... wepoker私局辅助!wpk透视工作室(透视)软件-真是解密真的是有挂1、wepoker私局辅助透...
透视详细!aapoker真的假... 透视详细!aapoker真的假的(透视)werplan怎么透视,教程办法(有挂神器)-哔哩哔哩1、w...
newpoker怎么安装脚本!... newpoker怎么安装脚本!约局吧德州真的有透视挂吗(透视)教程-总是了解是真的挂在进入约局吧德州...
透视分享!pokermaste... 透视分享!pokermaster辅助器(透视)大菠萝免费辅助器,教程手册(有挂分析)-哔哩哔哩运大菠...