视频自动播放带声音

在项目中遇到一个问题:

浏览器出于用户体验考虑,限制了视频自动播放声音,必须用户交互后才允许播放带声音的视频。

但我们的业务场景是需要在某些情况下由 JS 主动控制视频播放(带声音),这就和浏览器策略产生了冲突。

我们的解决方案是:

在用户首次点击页面时,通过 AudioContext 创建一个极短的静音音频 buffer 并播放,从而"解锁"浏览器的音频上下文权限。

一旦音频上下文被激活,后续就可以通过 JS 控制 video 正常播放声音。

最后再移除这个点击监听,避免影响页面其他逻辑。

复制代码
<!doctype html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <video class="videoDom" src="./what.mp4" style="display: none"></video>
    <script>
      let audioUnlocked = false;
      const unlockAudio = () => {
        if (audioUnlocked) return;
        // 创建 Web Audio
        const AudioContext = window.AudioContext || window.webkitAudioContext;
        const ctx = new AudioContext();
        // 创建一个极短的静音 Buffer(0.01 秒)
        const buffer = ctx.createBuffer(1, ctx.sampleRate * 0.01, ctx.sampleRate);
        const source = ctx.createBufferSource();
        source.buffer = buffer;
        // 连接输出
        source.connect(ctx.destination);
        // 播放并立即停止
        source.start(0);
        source.stop(0);
        audioUnlocked = true;
        console.log('🔓 音频通道已解锁!');
        // 不再监听
        window.removeEventListener('click', unlockAudio);

        // 这里模拟 到指定页面后,需要播放带声音的视频
        let videoDom = document.querySelector('.videoDom');
        videoDom.play();
      };
      window.addEventListener('click', unlockAudio);
    </script>
  </body>
</html>
相关推荐
DogDaoDao7 小时前
Android 硬件编码器参数完全指南:MediaCodec 深度解析
android·音视频·视频编解码·h264·硬编码·视频直播·mediacodec
音视频牛哥9 小时前
大牛直播SDK(SmartMediaKit)Windows平台RTSP/RTMP直播播放SDK集成说明(C#版)
音视频·低延迟rtsp播放器·windows rtsp播放器·windows rtmp播放器·低延迟rtmp播放器·c# rtsp播放器·c# rtmp播放器
薛定猫AI11 小时前
【深度解析】Gemini Omni 多模态生成与 Agent 化创作工作流:从视频编辑到 UI 生成的技术演进
人工智能·ui·音视频
音视频牛哥19 小时前
大牛直播SDK(SmartMediaKit)Windows平台RTSP/RTMP直播播放SDK集成说明(C++版)
windows·音视频·实时音视频·windows rtsp播放器·windows rtmp播放器·超低延迟rtsp播放器·超低延迟rtmp播放器
EasyGBS21 小时前
1分钟讲清楚选EasyNVR还是国标GB28181视频平台EasyGBS:路线不同,别选错
音视频
日光明媚1 天前
深度解析 SGLang 框架 Wan2.1 视频生成加速技术:从 49 分钟到 1 分钟的极致优化
人工智能·计算机视觉·aigc·音视频·sglang
小猿君1 天前
谷歌I/O前夜Veo 4遭泄露,AI视频底层逻辑浮出水面
人工智能·音视频
南山有乔木7891 天前
音频怎么转换MP3格式?M4A、WAV、FLAC转mp3实测有效的格式转换方法
音视频
不昀1 天前
音频变压器Bourns SM-LP-5001国产替代选型指南
网络·音视频·以太网·网络通信·电子元器件
REDcker1 天前
RGB与YUV像素格式详解
音视频·实时音视频·视频编解码·yuv·rgb