gpt4 book ai didi

javascript - MediaSource 从不在 React 中发出 sourceopen 事件

转载 作者:行者123 更新时间:2023-12-05 05:49:03 31 4
gpt4 key购买 nike

我正在尝试在 React 自定义 Hook 中使用 Javascript 的 MediaSource API 流式传输视频文件。

这是我的代码片段:

const useMyHook = (videoRef: React.MutableRefObject<HTMLVideoElement | null>) => {
...
useEffect(() => {
const mediaSource = new MediaSource();
videoRef.current!.src = URL.createObjectURL(mediaSource);
mediaSource.addEventListener('sourceopen', () => {
// this never happens
});
}, []);
...
}
const MyComponent = () => {
const videoRef = useRef<HTMLVideoElement | null>(null);
const {} = useMyHook(videoRef);

return (
<>
<video ref={videoRef} controls />;
</>
);
};

看起来 mediaSource 从未发出 'sourceopen' 事件。

此外,当我尝试在不同的项目中使用简单的 html 和 javascript 时,它工作正常。

我试图使用 document.getElementByTagName 而不是 useRef 或直接在我的组件中使用它,但结果相同。

有人能告诉我这是什么问题吗? React 什么的有什么问题吗?

最佳答案

在整个组件范围内实例化和维护 MediaSource 的状态:

import React, { useState, useEffect, useRef } from 'react'

const MyComponent = () => {
const [mediaSource] = useState(new MediaSource())
const videoRef = useRef<HTMLVideoElement | null>(null)

// component init
useEffect(() => {
mediaSource.addEventListener('sourceopen', ...)
}, [])

// videoRef changes
useEffect(() => {
videoRef?.current!.src = URL.createObjectURL(mediaSource)
}, [videoRef])
};

关于javascript - MediaSource 从不在 React 中发出 sourceopen 事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70717575/

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