2017-12-28 150 views
0

私は新しいBarchartを開発するためにD3を試しています。これは私の最初の試みですd3エラー:<rect>属性y:予想される長さ "NaN"。 D3 JS

私は1つの記事Hereに続き、それに基づいて私は下のコードを書いて1つの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; 
} 
}); 

ように私は、データ形式1つのAJAXリクエストやAjaxのレスポンスを引っ張っています以下のように見えます。

[ { "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)は、{)d.jobs_fail(Yを返します;}) ' –

+0

@PeterBもっと詳しく教えてください。 – burning

+0

私のコメントははっきりしているはずです。しかし、私はあなたが変数 'x'と' y'を持っていることに気付き、また 'x(...)'と 'y(...)'という関数を呼び出すように見えます。既に問題が発生している可能性があります。これを修正するには、変数または関数の名前を変更する必要があります。たとえば、関数の名前を 'getX(...)'と 'getY(...) 'に変更します。 –

答えて

1

こんにちは、私はこの問題を解決することができます。

問題は以下のコードにあります。値を添付することができませんので、データ値がないので、私は.datadataを使用しています一方、私はobjという変数に解析されdataを格納しています

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とデータを交換し、それが私の作品。すべてのご支援のための

おかげ

関連する問題