Ich kopierte ein Beispiel aus dem Buch D3.js In Aktion für ein einfaches Balkendiagramm und bekomme einen Fehler, wenn ich versuche, es auszuführen.D3.js In Action, Codebeispiel funktioniert nicht
Console Fehler:
charts.js:3 Uncaught TypeError: Cannot read property 'linear' of undefined
Der Code:
var yScale = d3.scale.linear().domain([0, 390]).range([0,100]);
d3.select('svg')
.selectAll('rect')
.data([150,390,340,295])
.enter()
.append('rect')
.attr('width', 50)
.attr('height', function(d) { return yScale(d); })
.attr('x', function(d, i) { return i*60; })
.attr('y', function(d) { return 100 - yScale(d); })
.style('fill', 'rgb(104, 167, 207)');
Wenn ich die yScale
Erklärung nach unten bewege ich die folgende Fehlermeldung erhalten:
charts.js:11 Uncaught TypeError: yScale is not a function
danke, das hat den ersten Fehler behoben. Jetzt bekomme ich: Uncaught TypeError: yScale ist keine Funktion Gibt es eine aktualisierte Möglichkeit, yScale die Daten 'd' zu übergeben? –
@RonI In deiner Frage hast du erwähnt, dass du die Deklaration nach unten verschiebst. Haben Sie es seitdem wieder über die Position gebracht, an der es zum ersten Mal benutzt wird? Wenn yScale noch nicht zugewiesen ist, ist es sicherlich keine Funktion, genauso wie der Fehler angegeben wurde – altocumulus