새로운 Barchart를 개발하기 위해 D3을 사용하려고합니다. 이것은 d3에 내 첫 시도입니다오류 : <rect> 특성 y : 예상 길이 "NaN". D3 JS
나는 Here 한 기사를 따라 그것을 기반으로 아래 코드를 작성하여 하나의 barchart를 개발하려고합니다.
function get_data() {
console.log("create post is working!") // sanity check
return $.ajax({
url : "/group/guest/query/", // the endpoint
type : "GET", // http method
});
};
var margin = {
top: 20,
right: 20,
bottom: 30,
left: 40
},
width = 960 - margin.left - margin.right,
height = 500 - margin.top - margin.bottom;
var x = d3.scale.ordinal()
.rangeRoundBands([0, width], .1);
var y = d3.scale.linear()
.range([height, 0]);
var xAxis = d3.svg.axis()
.scale(x)
.orient("bottom");
var yAxis = d3.svg.axis()
.scale(y)
.orient("left")
.ticks(10, "");
var svg = d3.select("#chart").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
var ajdata = get_data();
var k = [];
ajdata.success(function (data) {
var obj = jQuery.parseJSON(data);
obj.forEach(function(d) {
d.created_date = d.created_date;
d.jobs_fail = +d.jobs_fail;
k.push(d.created_date)
});
x.domain(obj.map(function(d) {
return d.date_created;
}));
y.domain([0, d3.max(obj, function(d) {
//alert(JSON.stringify(d.jobs_fail));
return d.jobs_fail;
})]);
svg.append("g")
.attr("class", "x axis")
.attr("transform", "translate(0," + height + ")")
.call(xAxis);
svg.append("g")
.attr("class", "y axis")
.call(yAxis)
.append("text")
.attr("transform", "rotate(-90)")
.attr("y", 6)
.attr("dy", ".71em")
.style("text-anchor", "end")
.text("Count");
svg.selectAll(".bar")
.data(data)
.enter().append("rect")
.attr("class", "bar")
.attr("x", function(d) {
return x(d.date_created);
})
.attr("width", x.rangeBand())
.attr("y", function(d) {
return y(d.jobs_fail);
})
.attr("height", function(d) {
return height - y(d.jobs_fail);
});
function type(d) {
d.jobs_fail = +d.jobs_fail;
return d;
}
});
내가 데이터 형태를 한 아약스 요청을 당겨 오전 아약스 응답은 다음과 같습니다처럼 내 코드 모양.
[ { "date": "2017-12-28", "jobs_fail": 2, "jobs_resub": 7, "jobs_success": 18 }, { "date": "2017-12-27", "jobs_fail": 20, "jobs_resub": 31, "jobs_success": 50 }, { "date": "2017-12-26", "jobs_fail": 22, "jobs_resub": 27, "jobs_success": 49 }, { "date": "2017-12-25", "jobs_fail": 11, "jobs_resub": 8, "jobs_success": 18 }, { "date": "2017-12-24", "jobs_fail": 5, "jobs_resub": 2, "jobs_success": 4 }, { "date": "2017-12-23", "jobs_fail": 10, "jobs_resub": 16, "jobs_success": 23 }, { "date": "2017-12-22", "jobs_fail": 51, "jobs_resub": 54, "jobs_success": 97 } ]
나는 내가 error.But 내 x 축 날짜 (CREATED_DATE)을 얻고이 코드를 실행
데이터가 차트의 x 축에 게재 제기했다.Error: <rect> attribute y: Expected length, "NaN".
나는이 Y 축에 뭔가하지만 난 그게 내가 잘못 여기서 뭐하는 거지 모른 무슨 날 가이드하시기 바랍니다에 대한 모든 솔루션을 찾을 수 없습니다 나는 이해합니다.
는'함수 y를 (...)'이 여기에 호출되는주십시오 :'.attr ("Y", 기능의 (d) {Y (d.jobs_fail을 반환) ;})' –
@ PeterB 더 자세히 설명해주세요. – burning
내 의견은 분명해야합니다. 그러나 나는 당신이 변수'x'와'y'를 가지고 있음을 주목했고'x (...)'와'y (...) '라는 함수를 호출하는 것처럼 보인다. 이미 문제가 발생했을 가능성이 높습니다. 이 문제를 해결하려면 변수 또는 함수의 이름을 바꿔야합니다. 예 : 함수의 이름을'getX (...)'와'getY (...) '로 변경하십시오. –