[英]Manipulating Javascript Data to Toggle Series on D3.js
我在flot( http://www.flotcharts.org/flot/examples/series-toggle/index.html )上遵循此示例,以将该概念应用于D3.js。
我的数据看起来像这样:
[ { "sourceA" : 28, "sourceB": 25, "sourceC": 20, "date": "29-Apr-13",
"sourceA" : 15, "sourceB": 23, "sourceC": 54, "date": "29-May-13",
"sourceA" : 23, "sourceB": 43, "sourceC": 23, "date": "29-Jun-13",
}]
我已经按照上述示例的源代码设置了复选框(“ sourceA”,“ sourceB”等)。 但是,我对如何使用“ plotAccordingToChoices”功能处理数据感到困惑。
即,如果选中了sourceA复选框,则该函数应将数据更改为:
[ { "sourceA" : 28, "date": "29-Apr-13",
"sourceA" : 15, "date": "29-May-13",
"sourceA" : 23, "date": "29-Jun-13",
}]
该示例中的示例代码-http: //www.flotcharts.org/flot/examples/series-toggle/index.html
// insert checkboxes
var choiceContainer = $("#choices");
$.each(datasets, function(key, val) {
choiceContainer.append("<br/><input type='checkbox' name='" + key +
"' checked='checked' id='id" + key + "'></input>" +
"<label for='id" + key + "'>"
+ val.label + "</label>");
});
choiceContainer.find("input").click(plotAccordingToChoices);
function plotAccordingToChoices() {
var data = [];
choiceContainer.find("input:checked").each(function () {
var key = $(this).attr("name");
if (key && datasets[key]) {
data.push(datasets[key]);
}
});
if (data.length > 0) {
$.plot("#placeholder", data, {
yaxis: {
min: 0
},
xaxis: {
tickDecimals: 0
}
});
}
}
plotAccordingToChoices();
过滤器函数的代码如下所示。
function filter(json, attrName) {
var newJson = [];
json.forEach(function(d) {
newJson.push({ "date": d.date, attrName: d[attrName] });
});
return newJson;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.