gpt4 book ai didi

reactjs - 每次鼠标悬停时重新绘制自定义标签渲染

转载 作者:行者123 更新时间:2023-12-04 08:02:18 24 4
gpt4 key购买 nike

我为 PieChart 创建自定义标签
CustomLabel.js

const renderCustomizedLabel = (props,centerText) => {
console.log("rendered")
return (
<g>...</g>
);
};

export default renderCustomizedLabel;
CustomPieChart.js
export default class Example extends PureComponent {
constructor(props){
super(props);
}
render() {
return (
<ResponsiveContainer width="100%" aspect={2}>
<PieChart width={600} height={600}>
<Pie
data={this.props.data}
dataKey="value"
nameKey="name"
cx="50%" cy="50%" innerRadius={80} outerRadius={90}
label={(a)=>CustomPieChartLabel(a,this.props.centerText)}>
{this.props.data.map((entry, index) => (<Cell key={`cell-${index}`} fill={entry.color} />))}
</Pie>
</PieChart>
</ResponsiveContainer>
);
}
}
问题
每次将鼠标悬停在单元格上时, renderCustomizedLabel 都会工作并为每个数据渲染。
在上面的代码中,我没有使用任何 onMouseMove、onMouseOver、onMouseEnter 方法。
enter image description here
如上图所示,当鼠标悬停在红色、蓝色或灰色区域时,console.log("rendered") 工作 3 次。
为了解决这个问题,我尝试使用 React.memo
CustomLabelWithMemo.js
const MemoComponent = React.memo(function renderCustomizedLabel(props) {
console.log("rendered")
return (
<g>...</g>
);
});

export default MemoComponent
但它给了我一个错误

TypeError: Object(...) is not a function


我怎么解决这个问题?
转载链接
CodeSandBox

最佳答案

我认为查看沙箱的主要问题是您仍在使用 MemoComponent好像它是一个常规函数,而不是将它传递给 label 时的组件您的 Pie成分。
你做这个:

label={(a) => CustomPieChartLabel(a, this.props.centerText)}
相反,您可以执行以下操作:
label={<CustomPieChartLabel centerText={this.props.centerText} />}
我也稍微调整了你的 CustomPieChartLabel.js文件:
import React from "react";

const RADIAN = Math.PI / 180;

const renderCustomizedLabel = (props) => {
console.log("rendered");
const {
cx,
cy,
midAngle,
outerRadius,
fill,
payload,
percent,
value,
centerText
} = props;
const sin = Math.sin(-RADIAN * midAngle);
const cos = Math.cos(-RADIAN * midAngle);
const sx = cx + (outerRadius + 10) * cos;
const sy = cy + (outerRadius + 10) * sin;
const mx = cx + (outerRadius + 30) * cos;
const my = cy + (outerRadius + 30) * sin;
const ex = mx + (cos >= 0 ? 1 : -1) * 30;
const ey = my;
const textAnchor = cos >= 0 ? "start" : "end";
return (
<g>
<text x={cx} y={cy} textAnchor="middle" fill={fill}>
{centerText.title}
</text>
<text x={cx} y={cy} dy={20} textAnchor="middle" fill={fill}>
{centerText.value}
</text>

<path
d={`M${sx},${sy}L${mx},${my}L${ex},${ey}`}
stroke={fill}
fill="none"
/>
<circle cx={ex} cy={ey} r={2} fill={fill} stroke="none" />
<text
style={{ fontWeight: "bold" }}
x={ex + (cos >= 0 ? 1 : -1) * 12}
y={ey}
textAnchor={textAnchor}
fill={fill}
>
{payload.name}
</text>
<text
x={ex + (cos >= 0 ? 1 : -1) * 12}
y={ey}
dy={18}
textAnchor={textAnchor}
fill="#999"
>
{value}
</text>
</g>
);
};

const CustomPieChartLabel = React.memo(renderCustomizedLabel);

export default CustomPieChartLabel;
Sandbox example

关于reactjs - 每次鼠标悬停时重新绘制自定义标签渲染,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66397172/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com