Angular应用程序中的图表和窗口不会自适应大小。
创始人
2024-10-30 15:00:32
0

问题通常是由于未正确定义组件的尺寸所致。如果使用 Chart.js 等外部图库,则需要定义图表和窗口组件的宽度和高度。以下示例代码为在 Angular 应用程序中使用 Chart.js 的组件提供了解决方案:

HTML 文件:

TypeScript 文件:

import { Component, ElementRef, ViewChild } from '@angular/core';
import { Chart } from 'chart.js';

@Component({
  selector: 'app-chart',
  templateUrl: './chart.component.html',
  styleUrls: ['./chart.component.css']
})
export class ChartComponent {
  @ViewChild('myChart') private chartRef: ElementRef;
  private chart: any;
  chartWidth: number;
  chartHeight: number;

  constructor() {
    this.chartWidth = 500;
    this.chartHeight = 300;
  }

  ngAfterViewInit() {
    this.chart = new Chart(this.chartRef.nativeElement, {...});
    this.updateChartDimensions();
  }

  private updateChartDimensions() {
    const width = this.chartRef.nativeElement.offsetWidth;
    const height = this.chartRef.nativeElement.offsetHeight;
    if (width && height) {
      this.chartWidth = width;
      this.chartHeight = height;
      this.chart.resize();
    }
  }
}

以上代码示例中,我们在 HTML 文件中使用了一个 div 元素,用于包装 canvas 元素,从而使其充满父容器。接下来,我们将 Canvas 元素绑定到通过 ViewChild 装饰器引用的元素。

在构造函数中,我们定义了图表和窗口组件的宽度和高度,这些属性将用于在根据 ClassName 加载组件时设置元素的大小时进行调整。在 ngAfterViewInit 方法中,我们实例化图表对象,并使用 updateChartDimensions 方法动态调整宽度和高

相关内容

热门资讯

透视教程!wpk透明挂,(Wp... 透视教程!wpk透明挂,(Wpk)原生真的有挂,黑科技新版(有挂工具)-哔哩哔哩;1、透视教程!wp...
透视ai(aapokER)透视... 透视ai(aapokER)透视辅助软件(透视)真是存在有挂(今日头条)-哔哩哔哩是一种具有地方特色的...
黑科技ai!(WePoKe)原... 黑科技ai!(WePoKe)原本存在有挂,(wepOke)原来真的有挂,黑科技最新款(有挂细节)-哔...
黑科技有挂!(WePoKe)最... 黑科技有挂!(WePoKe)最初是有挂,(wepokE)原来真的是有挂,黑科技稳赢(确实有挂)-哔哩...
1分钟辅助挂!微扑克ai辅助网... 1分钟辅助挂!微扑克ai辅助网页版,(微扑克)固有真的有挂,存在有挂(存在有挂)-哔哩哔哩1、这是跨...
3分钟黑科技!德扑ai软件,(... 3分钟黑科技!德扑ai软件,(德扑)竟然真的是有挂,大神讲解(有挂规律)-哔哩哔哩1、点击下载安装,...
透视黑科技(AAPoker)透... 透视黑科技(AAPoker)透视辅助插件(透视)都是是有挂(确实有挂)-哔哩哔哩;运辅助工具,进入游...
7分钟黑科技!德扑之星软件有啥... 7分钟黑科技!德扑之星软件有啥猫腻,(德扑)素来真的是有挂,揭秘攻略(有挂细节)-哔哩哔哩德扑之星软...
六分钟黑科技!德扑之星系统有哪... 六分钟黑科技!德扑之星系统有哪些规律,(德扑之星)先前有挂,扑克教程(新版有挂)-哔哩哔哩1、德扑之...
黑科技辅助挂!(WePoKe)... 黑科技辅助挂!(WePoKe)竟然真的有挂,(WepoKe)原来是真的有挂,黑科技挂(有挂神器)-哔...