1

我正在使用 ng2-nvd3,我想访问外部 json 数据。根据下面的代码片段,我如何引用 .json 文件来保存与下面 this.data 数组中显示的数据相同的数据?

import {Component} from 'angular2/core';
declare let d3:any;
import {nvD3} from 'ng2-nvd3';

@Component({
  selector: 'bar-chart',
  directives: [nvD3],
  template: `
    <div>
      <nvd3 [options]="options" [data]="data"></nvd3>
    </div>
  `
})
export class BarChartComponent {
  options;
  data;

  ngOnInit() {
    this.options = {
      chart: {
        type: 'discreteBarChart',
        height: 450,
        margin: {
          top: 20,
          right: 20,
          bottom: 50,
          left: 55
        },
        x: function (d) {
          return d.label;
        },
        y: function (d) {
          return d.value;
        },
        showValues: true,
        valueFormat: function(d){
          return d3.format(',.4f')(d);
        },
        duration: 500,
        xAxis: {
          axisLabel: 'X axis',
        },
        yAxis: {
          axisLabel: 'Y axis',
          axisLabelDistance: -10
        }
      }
    }

    //Want to replace this with an external json file.
    this.data = [
      {
        key: "Cumulative Return",
        values: [
          {
            "label": "A",
            "value": -29.765957771107
          },
          {
            "label": "B",
            "value": 0
          },
          {
            "label": "C",
            "value": 32.807804682612
          },
          {
            "label": "D",
            "value": 196.45946739256
          },
          {
            "label": "E",
            "value": 0.19434030906893
          },
          {
            "label": "F",
            "value": -98.079782601442
          },
          {
            "label": "G",
            "value": -13.925743130903
          },
          {
            "label": "H",
            "value": -5.1387322875705
          }
        ]
      }
    ];
  }

}
4

1 回答 1

0

如果您只想将数据放在单独的文件中。

创建一个新文件:

你的.data.service.ts

在那里:

export class YourDataService{


   public data: Array<any> = [
     {
       key: "Cumulative Return",
       values: [
         {
           "label": "A",
           "value": -29.765957771107
         }]
   }]

然后将其导入组件并引用它

import{YourDataService} from './your.data.service.ts'


public _data: Array<any>= YourDataService.data;
于 2016-05-09T21:09:33.790 回答