我尝试使用自定义工具提示但我的问题是我不知道如何获取悬停的有效负载的索引。我想要的是只显示工具提示中悬停线的值。例如,我在值1行上方盘旋,所以我只想在工具提示中显示值1。
所以这是图像
虽然我删除了自定义工具提示,但这是我的代码:
export default class LineChartPresentational extends React.Component {
constructor(props) {
super();
this.state = {
clickedLineid: '' }}
changeStrokeclick(data) {
console.log(data, 'see what is coming');
this.setState({clickedLineID: data} ) }
render() {
return (
<div>
<div id="lclastdataref" style={{ textAlign: 'right' }}>
<span>Last Data Refresh: {linechartdf.date} </span>
</div>
<div className='line-charts'>
<div className="line-chart-wrapper " style={{ width: window.innerWidth / 2, height: window.innerHeight / 2, }}>
<ResponsiveContainer>
<LineChart
width={width} height={height} margin={{ top: 20, right: 20, bottom: 20, left: 20 }} data={linechartdata} id="Line-Chart">
<XAxis dataKey={xAxisColumn} />
<YAxis domain={['auto', 'auto']} />
<Tooltip cursor={false} />
{
linechartdata.map((entry, index) => (
<Line stroke={index === this.state.clickedLineID ? "#2d75ed" : "#9da0a5"} onClick={this.changeStrokeclick.bind(this, index)} name={linechartdata[index].dataKey} strokeWidth={lineThickness} dataKey={`value${index + 1}`} dot={false} className={`value${index + 1}`}/>
))
}
</LineChart>
</ResponsiveContainer>
</div>
</div>
</div> ); }}
请真的需要你的帮助。谢谢!
答案 0 :(得分:3)
自定义工具提示是您执行此操作的选项。
<Tooltip content={this.customTooltipOnYourLine}/>
此处customTooltipOnYourLine
是您返回自定义工具提示的方法
customTooltipOnYourLine(e){
if (e.active && e.payload!=null && e.payload[0]!=null) {
return (<div className="custom-tooltip">
<p>{e.payload[0].payload["Column Name"]}</p>
</div>);
}
else{
return "";
}
}
点击此链接了解详情Recharts Tooltip
修改强>
检查此答案
答案 1 :(得分:0)
使用以下逻辑,您可以为每个点获得单独的工具提示。
演示链接:Line chart with custom Tooltip
隐藏默认工具提示
在行上添加鼠标事件功能(点处于活动状态时)
<Line
activeDot={{
onMouseOver: this.showToolTip,
onMouseLeave: this.hideToolTip
}}
....
/>
自定义工具提示div
<div className="ui-chart-tooltip" ref={ref => (this.tooltip = ref)} >
<div className="ui-chart-tooltip-content" />
</div>
showToolTip和hideTooltip函数
showToolTip = (e) => {
let x = Math.round(e.cx);
let y = Math.round(e.cy);
this.tooltip.style.opacity = "1";
this.tooltip.childNode[0].innerHTML = e.payload["value"];
};
hideTooltip = e => {
this.tooltip.style.opacity = "0";
};