16

有没有办法关闭Recharts中条形图悬停时出现的灰色背景?

条形图的屏幕截图,条形图后面出现灰色背景。

使用版本 1.4.1。代码(简化)如下所示:

import React from "react"

// Recharts
import { Bar, BarChart, CartesianGrid, ResponsiveContainer, Tooltip, XAxis, YAxis } from "recharts"

import CustomTooltip from "../CustomTooltip"

const BarChart = ({ chartData, chartInfo }) => (
  <ResponsiveContainer width="99%" height={260}>
    <BarChart data={chartData}>
      <XAxis
        dataKey="label"
        type="category"
        allowDuplicatedCategory={true}
        tickLine={false}
        orientation="bottom"
      />

      <YAxis
        tickLine={false}
        orientation="left"
        axisLine={false}
      />

      <Tooltip
        isAnimationActive={false}
        separator={": "}
        content={<CustomTooltip />}
      />

      <CartesianGrid vertical={false} />

      {chartInfo.map(bar => (
        <Bar
          key={bar.dataKey}
          name={bar.name}
          dataKey={bar.dataKey}
          isAnimationActive={false}
        />
      ))}
    </BarChart>
  </ResponsiveContainer>
)

export default BarChart

我翻阅了API 文档并查看了源代码。似乎不是一种方法,但有些演示禁用了它,比如这个

我尝试使用该演示之类的自定义形状设置我的,并使用Cell而不是渲染Bar,但悬停时背景仍然存在。背景颜色是#ccc,但使用该关键字搜索存储库没有产生明确的方法或道具来尝试覆盖或挂钩。

4

2 回答 2

31

您可以使用上的cursor道具<Tooltip />来实现您所需要的:

<Tooltip cursor={{fill: '#f00'}} />

是我根据他们文档中的一些示例制作的工作小提琴。

您可以简单地将transparent其用作fill属性的值。

const {BarChart, Bar, XAxis, YAxis, CartesianGrid, Tooltip, Legend} = Recharts;
const data = [
      {name: 'Page A', uv: 4000, pv: 2400, amt: 2400},
      {name: 'Page B', uv: 3000, pv: 1398, amt: 2210},
      {name: 'Page C', uv: 2000, pv: 9800, amt: 2290},
      {name: 'Page D', uv: 2780, pv: 3908, amt: 2000},
      {name: 'Page E', uv: 1890, pv: 4800, amt: 2181},
      {name: 'Page F', uv: 2390, pv: 3800, amt: 2500},
      {name: 'Page G', uv: 3490, pv: 4300, amt: 2100},
];
const SimpleBarChart = React.createClass({
	render () {
  	return (
    	<BarChart width={600} height={300} data={data}
            margin={{top: 5, right: 30, left: 20, bottom: 5}}>
       <CartesianGrid strokeDasharray="3 3"/>
       <XAxis dataKey="name"/>
       <YAxis/>
       <Tooltip cursor={{fill: 'transparent'}}/>
       <Legend />
       <Bar dataKey="pv" fill="#8884d8" />
       <Bar dataKey="uv" fill="#82ca9d" />
      </BarChart>
    );
  }
})

ReactDOM.render(
  <SimpleBarChart />,
  document.getElementById('container')
);
body {
  margin: 0;
}

#container {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  padding: 10px;
  width: 800px;
  height: 800px;
  background-color: #fff;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.24/browser.js"></script>
<script src="https://npmcdn.com/react@15.6.2/dist/react-with-addons.min.js"></script>
<script src="https://npmcdn.com/react-dom@15.6.2/dist/react-dom.min.js"></script>
<script src="https://npmcdn.com/prop-types@15.6.2/prop-types.min.js"></script>
<script src="https://npmcdn.com/recharts@1.4.2/umd/Recharts.min.js"></script>

<div id="container">
  <!-- This element's contents will be replaced with your component. -->
</div>

于 2019-01-23T15:21:27.703 回答
11

您提到的灰色区域称为cursor. 引用TooltipAPI 文档:

如果设置为 false,则在工具提示处于活动状态时不会绘制光标。

所以你的问题的答案是:

<Tooltip cursor={false} />

顺便说一句,我正在使用 recharts@1.7.1

于 2019-08-18T17:49:03.747 回答