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的图表,并在这之后重新渲染。

相关内容

热门资讯

透视方案!xpoker辅助神器... 透视方案!xpoker辅助神器(透视)悦扑克脚本(辅助)总是真的有神器(哔哩哔哩)1、上手简单,内置...
透视要领!悦扑克脚本(透视)p... 透视要领!悦扑克脚本(透视)pokemmo免费脚本(辅助)原来真的有攻略(哔哩哔哩)所有人都在同一条...
透视总结!约局吧透视挂下载(W... 透视总结!约局吧透视挂下载(WePoKer亲友圈)真是是真的有辅助脚本(哔哩哔哩)1、用户打开应用后...
透视机巧!hhpoker有后台... 透视机巧!hhpoker有后台操作吗(WePoKer线上)总是真的是有辅助神器(哔哩哔哩)hhpok...
透视积累!红龙poker辅助(... 透视积累!红龙poker辅助(透视)哈糖大菠萝攻略(辅助)真是有神器(哔哩哔哩)1、哈糖大菠萝攻略辅...
透视烘培!拱趴大菠萝挂哪里(W... 透视烘培!拱趴大菠萝挂哪里(WePoKer插件)其实存在有辅助教程(哔哩哔哩)透视烘培!拱趴大菠萝挂...
透视窍要!智星菠萝辅助(透视)... 透视窍要!智星菠萝辅助(透视)约局吧怎么看有没有挂(辅助)真是有软件(哔哩哔哩)1、不需要AI权限,...
透视练习!hhpoker透视脚... 透视练习!hhpoker透视脚本下载(HHpoker操作)原来有辅助方法(哔哩哔哩)1、hhpoke...
透视举措!竞技联盟透视(透视)... 透视举措!竞技联盟透视(透视)智星德州插件最新版本更新内容详解(辅助)其实一直都是有脚本(哔哩哔哩)...
透视窍门!aapoker怎么控... 透视窍门!aapoker怎么控制牌(WePoKer程序)一直是真的有辅助技巧(哔哩哔哩)1、aapo...