I d3 PCP Diagramm erstellt haben, und hier ist mein Code:d3.js: aktualisieren Sie die Grafik mit neuen Datensatz
var m = [60, 10, 10, 60],
w = 1000 - m[1] - m[3],
h = 270 - m[0] - m[2];
var x=d3.scaleOrdinal()
.range([0, w]),
y = {},
dragging = {};
var line = d3.line(),
background,
foreground;
var svg = d3.select("#test").append("svg:svg")
.attr("width", w + m[1] + m[3])
.attr("height", h + m[0] + m[2])
.append("svg:g")
.attr("transform", "translate(" + m[3] + "," + m[0] + ")");
//let dimensions
// Extract the list of dimensions and create a scale for each.
x.domain(this.dimensions = d3.keys(data[0]).filter(function(d) {
if (d === "name") return false;
if (d === "Plant" || d === "Chemical" || d === "Pathway" || d === "Gene" || d === "Disease") {
y[d] = d3.scaleOrdinal()
.domain(data.map(function(p) {
return p[d];
}))
.range([h, 0]);
} else {
y[d] = d3.scaleLinear().domain([0, d3.max(data.map(function(p) { return p[d]; }))]).range([h, 0]);
}
return true;
}));
//alert(this.dimensions)
// Add grey background lines for context.
background = svg.append("svg:g")
.attr("class", "background")
.selectAll("path")
.data(data)
.enter().append("svg:path")
.style('fill', 'none')
.attr("d", path.bind(this));
// Add blue foreground lines for focus.
foreground = svg.append("svg:g")
.attr("class", "foreground")
.selectAll("path")
.data(data)
.enter().append("svg:path")
.style('fill', 'none')
.style('stroke', 'steelblue')
.attr("d", path.bind(this));
// Add a group element for each dimension.
let g = svg.selectAll(".dimension")
.data(this.dimensions)
.enter().append("svg:g")
.attr("class", "dimension")
.attr("transform", function(d) {
return "translate(" + x(d) + ")";
})
// Add an axis and title.
g.append("svg:g")
.attr("class", "axis")
.each(function(d) {
d3.select(this).call(d3.axisLeft(y[d]));
})
.append("svg:text")
.attr("text-anchor", "middle")
.attr("y", -50)
.attr("x",-10)
.style("fill", "black")
.text(function(d) {return d });
var firstAxis = d3.selectAll('g.dimension g.axis');
firstAxis
.append("svg:image")
.attr('x',-20)
.attr('y',-60)
.attr('width', 40)
.attr('height', 60)
.attr("xlink:href", function(s) {
return "images/" + s+'.png';
});
function position(d) {
var v = dragging[d];
return v == null ? x(d) : v;
}
function transition(g) {
return g.transition().duration(500);
}
// Returns the path for a given data point.
function path(d) {
return line(this.dimensions.map(function(p) {
return [position(p), y[p](d[p])];
}));
}
Ich habe eine einfache Eingabe von auf meiner Webseite, die eine Eingabe anzeigt Drop-Down-und basiert auf Ausgewählter Wert, den wir jedes Mal übergeben, wenn sich unser neuer Datensatz im Skript befindet. Jedes Mal, wenn ein Benutzer einen Wert im Formular ändert, wird ein neues Dataset an mein Skript gesendet. Ich kämpfe, um herauszufinden, wie man das Diagramm mit neuem Datensatz aktualisiere (refresh), den ich versucht habe, 10 und remove
Funktion zu verwenden, aber nicht viel Erfolg.
svg.exit().remove();
: Vielen Dank für die schöne Erklärung, aber das Problem, dem ich jetzt gegenüberstehe, überschneiden sich meine Achse und Titel, wenn mein neuer Datensatz dynamisch hinzugefügt wird? – monu
Sie können den alten Titel und die Achsen entfernen (d3.selectAll (". Axis"). Remove()) oder sie alternativ mit einem Übergang aktualisieren (Achse, nicht Titel). Momentan zeichnen Sie sie jedes Mal neu, wenn Sie das obige Skript ausführen (das ist der Fall, wenn Sie die svg nicht jedes Mal vollständig entfernen). –