私はグラフ上で作業しています.d3 libで構築しています。D3:x軸の値に応じてy軸の目盛りにクラスを追加する
グラフはとてもシンプルなので、y軸上のユーロとx軸上のマネー、私は時間の経過とともに銀行口座の進化を示すことができます。
私はカントー私はこのような何かを持っているx軸を描き、その月のアカウントで利用できる対応する量に応じて、月のラベルにいくつかのスタイルを追加したい:
(D3データは、すべてのデータが含まれています効果的に軸を作成しますが、今、私はそれぞれ「ゼロ」、「最大」またはものは何でものように、スタイリングのためのいくつかのクラスをカチカチに広告したいことは
d3Data.xScale = d3.scale.ordinal().domain(
d3Data.dateStates.map(function(dateState) {
return dateState.xValue
})
);
xAxis = d3.svg.axis().scale(d3Data.xScale).orient("bottom")
d3Data.chart.append("g").call(xAxis)
)グラフを描画するために必要。
私の最初のアプローチは、すべてのダニを選択して、このような何かやっていた。
d3Data.chart.selectAll(".xAxisItemClass")
.attr('class', function(data, index) {
if (d3Data.months[index].value === 0)
return 'zero'
});
をしかし、D3データはattr()
呼び出しに2番目のパラメータとして渡された匿名関数内に存在しません。私はd3のような騒ぎですので、おそらく私は何かが不足しています。なぜなら、このような簡単なことは簡単にできるからです。
なぜ私はD3dataにアクセスできませんか?これどうやってするの?その配列は、匿名関数に表示されているので、事前に
おかげで:)
括弧付きの場合: '(条件は)' –
ただのミス申し訳ありませんが...私はコーヒーの構文を使用し、if文に括弧を追加するのを忘れ、それはでは私の問題ではない場合すべて – Alberto
'if(data === 0)'(フィドルなしであなたを助けるのは難しい) –