在 Recharts 的 BarChartStackedBySign 中,我想比较当前和上一年的给定实体,表示条形图上的实体。
问题是如果通过两个不同的对象提供,重新图表会将它们视为不同的实体。
在共享的小提琴中,我们可以看到每个水果在 x 轴上表示两次,我希望每个水果在 x 轴上只出现一次,当年的数据在 +y 轴上表示,上一年的数据在 -y 轴上表示。
小提琴链接 - https://jsfiddle.net/59ugdj1t/
const {BarChart, Bar, ReferenceLine, XAxis, YAxis, CartesianGrid, Tooltip, Legend} = Recharts;
// Data for current year
const data1 = [
{name: 'Apple', men: 4000, women: 2400},
{name: 'Orange', men: 2000, women: 2000},
{name: 'Kiwi', men: 1000, women: 1400},
];
// Data for previous year
const data2 = [
{name: 'Apple', men: -3000, women: -2000},
{name: 'Orange', men: -1000, women: -1000},
{name: 'Kiwi', men: -2000, women: -400},
];
const data = data1.concat(data2);
const SimpleBarChart = React.createClass({
render () {
return (
<BarChart width={600} height={300} data={data} stackOffset="sign"
margin={{top: 5, right: 30, left: 20, bottom: 5}}>
<CartesianGrid strokeDasharray="3 3"/>
<XAxis dataKey="name"/>
<YAxis/>
<Tooltip/>
<Legend />
<ReferenceLine y={0} stroke='#000'/>
<Bar dataKey="men" fill="#8884d8" stackId="stack" />
<Bar dataKey="women" fill="#82ca9d" stackId="stack" />
</BarChart>
);
}
})
ReactDOM.render(
<SimpleBarChart />,
document.getElementById('container')
);