Как исправить проблему передачи данных в дочерний компонент в angular с помощью библиотеки d3 - PullRequest
0 голосов
/ 07 апреля 2019

Я довольно новичок в библиотеке d3.js и пытаюсь создать очень простое угловое приложение, в котором я отображаю диаграмму с динамическими данными, передаваемыми в дочерний компонент, используя директиву * ngFor для создания нескольких дочерних компонентов, но вместоПередав данные всем дочерним компонентам, только первый получает все переданные данные, а остальные остаются пустыми.

Кажется, ничего не работает.

Компонент приложения

  _trucksUrl = 'http://localhost:3000/trucks';

  trucksInformation;

  constructor(private http: HttpClient){}

  getTrucks(){
    return this.http.get<any>(this._trucksUrl);
  }

  ngOnInit(){
    this.getTrucks().subscribe((response) => {
      this.trucksInformation = JSON.parse(response.trucks);
      console.log(this.trucksInformation);
    },
    error => {
      console.error(error);
    })
  }
}

Компонент приложения HTML

<div>
   <app-truckdata *ngFor="let truck of trucksInformation" [initialTruck] = "truck"></app-truckdata>
</div>

TruckComponent

import { Component, OnInit, AfterViewInit, Input, AfterContentInit } from '@angular/core';
import * as d3 from 'd3';

@Component({
  selector: 'app-truckdata',
  templateUrl: './truckdata.component.html',
  styleUrls: ['./truckdata.component.scss']
})
export class TruckdataComponent implements OnInit, AfterContentInit {

  @Input() initialTruck;

  truck = [];

  constructor() { }

  ngOnInit() {
    for(let key in this.initialTruck){
      if(typeof this.initialTruck[key] === 'object' || key === 'StationId') {
        continue;
      } else {
        let propObj = {
          propname: key,
          value: +this.initialTruck[key]
        };
        this.truck.push(propObj);
      }
    }
  }

  ngAfterContentInit() {
    let margin = { top: 30, right: 30, bottom: 70, left: 130 },
      width = 460 - margin.left - margin.right,
      height = 400 - margin.top - margin.bottom;

    let svg = d3.select(".truck-info")
      .append("svg")
      .attr("width", width + margin.left + margin.right)
      .attr("height", height + margin.top + margin.bottom)
      .append("g")
      .attr("transform",
        "translate(" + margin.left + "," + margin.top + ")");

    let x = d3.scaleLinear()
      .domain([0, 10000])
      .range([0, width]);
    svg.append('g')
      .attr('transform', `translate(0, ${height})`)
      .call(d3.axisBottom(x))
      .selectAll("text")
      .attr("transform", "translate(-10,0)rotate(-45)")
      .style("text-anchor", "end");

    let y = d3.scaleBand()
      .range([0, height])
      .domain(this.truck.map(function (d) { return d.propname; }))
      .padding(.1);
    svg.append("g")
      .call(d3.axisLeft(y));

    svg.selectAll('rect')
      .data(this.truck)
      .enter()
      .append('rect')
      .attr('x', x(0))
      .attr('y', function (d) { return y(d.propname) })
      .attr("width", function (d) { return x(d.value); })
      .attr("height", y.bandwidth())
      .attr("fill", "#69b3a2")
  }

}

Я ожидаю получить несколько дочерних компонентов, каждый из которых содержит одну диаграмму, но я получаю один дочерний компонент со всеми компонентами и всемиостальные дочерние компоненты остаются пустыми.example

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...