VIDEOJS: ERROR: (CODE:4 MEDIA_ERR_SRC_NOT_SUPPORTED) The media could not be loaded, either because t

文章讲述了在使用videojs第三方插件动态切换视频时遇到的问题,错误代码4MEDIA_ERR_SRC_NOT_SUPPORTED导致无法加载媒体。解决方法是检查并确保视频数据类型配置正确,特别是当提供流格式时。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景:使用videojs第三方插件,用于播放视频,videojs被封装成一个组件,通过点击事件达到如下目的:点击更改组件的src,以达到动态切换视频的效果。

出现问题:

点击事件不能实现视频的切换,控制台爆红如下:

中文翻译: 

VIDEOJS:错误:(代码:4 MEDIA_ERR_SRC_NOT_SUPPORTED)无法加载媒体,原因可能是服务器或网络出现故障,也可能是格式不受支持。

未捕获(承诺中)DOMException:由于找不到支持的源,无法加载。

解决思路:

 一、现有代码逻辑分析

页面布局:

页面逻辑:

封装的组件,核心代码:

主要是监听传过来的src是否改变,改变了之后对  当前播放器进行重置reset() -> load() -> play()。

因为load() 方法重新加载音频/视频元素。
load() 方法用于在更改来源或其他设置后对音频/视频元素进行更新。

watch(() => props.src, (now) => {
  if (now) {
    videoPlayer.pause()
    // videoPlayer.dispose()
    videoPlayer.reset()
    setTimeout(() => {
      videoPlayer.src([
        {
          src: props.src,
          type: "application/x-mpegURL"
        }
      ])
      videoPlayer.load()
      videoPlayer.play()
    }, 10)
  }
})

封装的组件,完整代码:

<script setup lang="ts">
import { computed, CSSProperties, onMounted, ref, watch } from 'vue'
import videojs from 'video.js'
import type { VideoJsPlayerOptions } from 'video.js'
import 'video.js/dist/video-js.min.css'
type MyVideoProps = {
  /** 视频地址 */
  src: string
  width?: string
  height?: string
}
const props = withDefaults(defineProps<MyVideoProps>(), {})
// video标签
const videoRef = ref<HTMLElement | null>(null)
// video实例对象
let videoPlayer: videojs.Player | null = null
const videoWrapStyles = computed<CSSProperties>(() => {
  return {
    width: props.width || '100%',
    height: props.height || '100%'
  }
})
// 初始化videojs
const initVideo = () => {
  // https://gitcode.gitcode.host/docs-cn/video.js-docs-cn/docs/guides/options.html
  const options: VideoJsPlayerOptions = {
    language: 'zh-CN', // 设置语言
    controls: true, // 是否显示控制条
    preload: 'auto', // 预加载
    autoplay: true, // 是否自动播放
    fluid: false, // 自适应宽高
    src: props.src, // 要嵌入的视频源的源 URL
    objectFit: 'cover', // 同css object-fit,作用于video标签
    notSupportedMessage: 'Ajiang此视频暂无法播放,请稍后再试' //允许覆盖Video.js无法播放媒体源时显示的默认信息。
  }
  if (videoRef.value) {
    // 创建 video 实例
    videoPlayer = videojs(videoRef.value, options, onPlayerReady)
  }
}
// video初始化完成的回调函数
const onPlayerReady = () => { }
onMounted(() => {
  initVideo()
})
watch(() => props.src, (now) => {
  if (now) {
    videoPlayer.pause()
    // videoPlayer.dispose()
    videoPlayer.reset()
    setTimeout(() => {
      videoPlayer.src([
        {
          src: props.src,
          type: "application/x-mpegURL"
        }
      ])
      videoPlayer.load()
      videoPlayer.play()
    }, 10)
  }
})
</script>
<template>
  <div :style="videoWrapStyles">
    <video id="my-player" ref="videoRef" class="video-js w-full h-full">
      <source :src="src" />
    </video>
  </div>
</template>
<style lang="less" scoped>
.w-full {
  width: 100%;
}

.h-full {
  height: 100%;
}
</style>

解决办法:

根据现有代码进行分析,发现传过来的视频的数据类型type写法有误。因为vediojs的播放器有三个参数,第二个参数使用js进行赋值的时候,type字段可以不写,如果写了传过来的视频流的数据格式一定要满足,否则不成功。

所以解决办法就是把type去掉。

备注:

videojs方法接收3个参数:

  • 第一个是dom节点的ID名称。
  • 第二个是一些配置项的内容。
  • 第三个则是自定义插件的配置,通常会在videojs 挂载后执行,也可以理解为videojs的 mounted 阶段。

### 解析 EasyPlayer 中 VIDEOJS ERROR CODE:4 MEDIA_ERR_SRC_NOT_SUPPORTED 当遇到 `VIDEOJS: ERROR: (CODE:4 MEDIA_ERR_SRC_NOT_SUPPORTED)` 错误时,表明 Video.js 尝试加载的媒体文件或流格式不受当前浏览器支持[^1]。此问题可能由多种因素引起: #### 原因分析 - **源文件格式不兼容**:某些视频编码或容器格式可能未被目标设备上的Video.js版本所识别和支持。 - **RTMP 流不再受支持**:由于现代浏览器已停止对 Flash 的支持,基于 RTMP 协议传输的内容即使引入了 videojs-flash 插件也无法正常工作[^4]。 - **DOM 节点初始化异常**:如果在创建播放器实例之前未能正确设置资源路径(即 src 属性为空),同样会触发此类错误。 #### 推荐解决方案 针对上述情况,可以采取如下措施来解决问题并优化用户体验: ##### 使用 HLS 或 DASH 格式的直播/点播服务 HLS 和 DASH 是两种广泛应用于互联网音视频分发的标准协议,具有良好的跨平台适配性和稳定性。特别是对于移动端应用而言,这两种格式几乎得到了所有主流操作系统的原生支持。 ```javascript // 示例代码展示如何配置 hls 类型的数据源 const playerOptions = { sources: [{ type: 'application/x-mpegURL', // or 'application/dash+xml' for dash streams src: '/path/to/hls.m3u8' }] }; ``` ##### 集成第三方插件增强功能 为了更好地处理不同类型的输入数据以及提供更丰富的特性集,可以在项目中集成官方推荐或者社区开发维护的相关扩展组件。例如,在面对 FLV 格式素材时可考虑采用 flv.js 库作为辅助解析工具;而对于 WebRTC 场景下的实时互动需求,则有专门设计的支持模块可供选用。 ##### 动态检测与回退机制 考虑到实际环境中可能存在各种不可预见的情况,构建一套完善的错误捕捉逻辑显得尤为重要。通过监听特定事件(如 canplaythrough)、捕获潜在异常并向用户提供友好的提示信息等方式能够有效提升整体健壮性。 ```javascript player.on('error', function() { console.log(player.error()); if (player.error().code === MediaError.MEDIA_ERR_SRC_NOT_SUPPORTED) { alert("The current format is not supported by your browser."); // Implement fallback logic here... } }); ``` #### 注意事项 确保所提供的多媒体内容遵循最新标准和技术趋势,及时更新依赖库至稳定版次以获得更好的性能表现和安全防护能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值