使用 React,我有一个以这种方式静态声明的 ref 列表:
let line1 = useRef(null);
let line2 = useRef(null);
let line3 = useRef(null);
...
//IN MY RENDER PART
<li ref={(el) => (line1 = el)}>line1</li>
<li ref={(el) => (line2 = el)}>line1</li>
<li ref={(el) => (line3 = el)}>line1</li>
然后将 refs 传递给动画函数,一切正常;现在事情发生了一些变化,我使用地图创建了列表项,我不再能够正确地引用元素;我试过类似的东西:
{menu.menu.map((D) => {
let newRef = createRef();
LiRefs.push(newRef);
return (
<li
key={D.id}
ref={(el) => (newRef = el)} >
{D.label}
</li>
);
})}
但是我传递给动画函数的数组是空的(我猜是因为函数在 useEffect 钩子中被调用,而 LiRefs 还不是 useRef)我也知道
ref={(el) => (`line${i}` = el)}
哪个不起作用我可以尝试的任何其他解决方案?