html限制仅有一个音/视频可播放

html限制仅有一个音/视频可播放

js 复制代码
/** 多个音频仅能播放一个 */
function audiosPlay() {
  const audios = document.getElementsByTagName('audio');
  const videos = document.getElementsByTagName('video');

  function pauseAll() {
    var self = this;
    [].forEach.call(audios, function (i) {
      if (i !== self) i.pause();
    });
    [].forEach.call(videos, function (i) {
      i.pause();
    });
  }

  [].forEach.call(audios, function (i) {
    i.addEventListener('play', pauseAll.bind(i));
  });
}

/** 多个视频仅能播放一个 */
function videosPlay() {
  const audios = document.getElementsByTagName('audio');
  const videos = document.getElementsByTagName('video');

  function pauseAll() {
    var self = this;
    [].forEach.call(videos, function (i) {
      if (i !== self) i.pause();
    });
    [].forEach.call(audios, function (i) {
      i.pause();
    });
  }

  [].forEach.call(videos, function (i) {
    i.addEventListener('play', pauseAll.bind(i));
  });
}
相关推荐
前端Hardy4 小时前
面试官:JS数组的常用方法有哪些?这篇总结让你面试稳了!
javascript·面试
yuki_uix4 小时前
Props、Context、EventBus、状态管理:组件通信方案选择指南
前端·javascript·react.js
全栈老石4 小时前
手写无限画布4 —— 从视觉图元到元数据对象
前端·javascript·canvas
Leon6 小时前
新手引导 intro.js 的使用
前端·javascript·vue.js
牛奶7 小时前
JS随笔:浏览器 API(DOM 与 BOM)
前端·javascript·面试
牛奶7 小时前
JS随笔:异步编程与事件循环
前端·javascript·面试
牛奶7 小时前
JS随笔:数据结构与集合
前端·javascript·面试
小陆猿7 小时前
股票实时行情Echarts动态图表
前端·javascript
牛奶7 小时前
JS随笔:ES6+特性与模块化实践
前端·javascript
牛奶8 小时前
JS随笔:基础语法与控制结构
前端·javascript