【问题标题】:Amcharts: change entire datasetAmcharts:更改整个数据集
【发布时间】:2019-01-11 09:21:49
【问题描述】:

我开始使用 amcharts 4 并且遇到了问题:根据更改图表数据集的文档,只需将新的对象数组分配给 chart.data:

chart.data = [{ some data object }, {}......]

它似乎对我有用,请查看此代码笔:https://codepen.io/anon/pen/LMgEjV

/**
 * ---------------------------------------
 * This demo was created using amCharts 4.
 *
 * For more information visit:
 * https://www.amcharts.com/
 *
 * Documentation is available at:
 * https://www.amcharts.com/docs/v4/
 * ---------------------------------------
 */

// Create chart instance
var chart = am4core.create("chartdiv", am4charts.PieChart);

// Add data
chart.data = [{
  "country": "Lithuania",
  "litres": 501.9
}, {
  "country": "Czech Republic",
  "litres": 301.9
}, {
  "country": "Ireland",
  "litres": 201.1
}, {
  "country": "Germany",
  "litres": 165.8
}, {
  "country": "Australia",
  "litres": 139.9
}, {
  "country": "Austria",
  "litres": 128.3
}, {
  "country": "UK",
  "litres": 99
}, {
  "country": "Belgium",
  "litres": 60
}, {
  "country": "The Netherlands",
  "litres": 50
}];

// Add and configure Series
var pieSeries = chart.series.push(new am4charts.PieSeries());
pieSeries.dataFields.value = "litres";
pieSeries.dataFields.category = "country";

function changeData() {
  chart.data = [{
    "country": "Lithuania",
    "litres": 501.9
   }, {
      "country": "Czech Republic",
      "litres": 301.9
    }
  ];
  
  chart.validateData();
}
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
}

#chartdiv {
  width: 100%;
  height: 400px;
}
<script src="https://www.amcharts.com/lib/4/core.js"></script>
<script src="https://www.amcharts.com/lib/4/charts.js"></script>
<button id="btn-change" onClick="changeData()">Click Me</button>
<div id="chartdiv"></div>

我错过了什么?

【问题讨论】:

    标签: javascript amcharts


    【解决方案1】:

    我不是 100% 确定我理解了这个问题,但无论如何我都会尽力帮助你,我检查了你的代码,我认为主要问题是因为你将整个数组推送到 chart.data 而不仅仅是你想要的对象改变。请看我的代码:

    function changeData() {
        chart.data.push({
            "country": "Lithuania",
            "litres": "501.9"
           })
    
     chart.validateData();
    }
    

    【讨论】:

    • 嗨,Tomer,我需要做的是替换整个数据集,而不是添加其他项目。文档说分配新对象应该可以解决问题,但这里有些东西不起作用amcharts.com/docs/v4/concepts/data/#Replacing_whole_data_set
    • 嗨,kathrine0,我试图再次查看您的代码,现在由于某种原因,它正在工作,我拿走了您的代码,这次我没有更改它,当我按下按钮时整个数据正在更改为新数据。这很奇怪
    • 他们似乎在周末修复了它:github.com/amcharts/amcharts4/commit/… 引用更改日志:“### 已修复 - ColumnSeries 的图表在更新 data 时因错误而失败。”跨度>
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-03-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-11-19
    相关资源
    最近更新 更多