2017-12-28 33 views
0

새로운 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 축에 뭔가하지만 난 그게 내가 잘못 여기서 뭐하는 거지 모른 무슨 날 가이드하시기 바랍니다에 대한 모든 솔루션을 찾을 수 없습니다 나는 이해합니다.

+0

는'함수 y를 (...)'이 여기에 호출되는주십시오 :'.attr ("Y", 기능의 (d) {Y (d.jobs_fail을 반환) ;})' –

+0

@ PeterB 더 자세히 설명해주세요. – burning

+0

내 의견은 분명해야합니다. 그러나 나는 당신이 변수'x'와'y'를 가지고 있음을 주목했고'x (...)'와'y (...) '라는 함수를 호출하는 것처럼 보인다. 이미 문제가 발생했을 가능성이 높습니다. 이 문제를 해결하려면 변수 또는 함수의 이름을 바꿔야합니다. 예 : 함수의 이름을'getX (...)'와'getY (...) '로 변경하십시오. –

답변

1

안녕하세요. 많은 시간을 보내고 의견을 보내 주신 후이 문제를 해결할 수 있습니다.

문제는 아래 코드에 있습니다.

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); 
    }); 

는 값이 단지 OBJ와 데이터를 대체 첨부 할 수 없습니다 그래서 내가 값은 내가 데이터 이후 .data 아래 data를 사용하고있는 반면 obj라는 변수로 분석 data을했다 저장하지 오전 나를 위해 작동 . 모든 지원

감사