作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有多个按钮,单击它们会触发不同的音频文件。
我设法为每个按钮使用不同的 useRef
使其工作,但我想有更好的方法来实现这一点:
const App = () => {
const myAudio1 = useRef()
const myAudio2 = useRef()
const myAudio3 = useRef()
const handleAudio1 = () => {
myAudio1.current.play()
}
const handleAudio2 = () => {
myAudio2.current.play()
}
const handleAudio3 = () => {
myAudio3.current.play()
}
return (
<div id="drum-machine">
<div onClick={() => handleAudio1()} id="Btn1">
<div> Button 1
<audio ref={myAudio1}>
<source id="Btn1" src="drumSounds/sound1.wav" type="audio/mpeg"/>
</audio>
</div>
</div>
<div onClick={() => handleAudio2()} id="Btn2">
<div> Button 2
<audio ref={myAudio2}>
<source id="Btn2" src="drumSounds/sound2.wav" type="audio/mpeg"/>
</audio>
</div>
</div>
<div onClick={() => handleAudio3()} id="Btn3">
<div> Button 3
<audio ref={myAudio3}>
<source id="Btn3" src="drumSounds/sound3.wav" type="audio/mpeg"/>
</audio>
</div>
</div>
</div>
)
}
最佳答案
您不能在循环中使用 React Hooks,但您可以将使用 useRef
的代码封装到它自己的组件中,然后为每个音频源渲染该组件。例如:
const AudioSource = ({ children, src, encoding = "audio/mpeg" }) => {
const ref = React.useRef();
const onClick = React.useCallback(() => {
if (ref.current === undefined) {
return;
}
ref.current.play();
}, []);
return (
<div onClick={onClick}>
{children}
<audio ref={ref}>
<source src={src} type={encoding} />
</audio>
</div>
);
};
然后可以这样调用:
const App = () => {
const sources = [
{
id: "Btn1",
text: "Button 1",
source: "drumSounds/sound1.wav"
},
{
id: "Btn2",
text: "Button 2",
source: "drumSounds/sound2.wav"
},
{
id: "Btn3",
text: "Button 3",
source: "drumSounds/sound3.wav"
}
];
return (
<div id="drum-machine">
{sources.map(audioSource => (
<div key={audioSource.id} id={audioSource.id}>
<AudioSource src={audioSource.src}>{audioSource.text}</AudioSource>
</div>
))}
</div>
);
};
关于reactjs - 如何对多个元素使用一个 useRef?或者如何将 useRef 用于类似的行为?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59448579/
我是一名优秀的程序员,十分优秀!