IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> video多少视频切换思路后———实现,流畅 -> 正文阅读

[JavaScript知识库]video多少视频切换思路后———实现,流畅

组件实现?

<template>
  <div class="video-bk">
    <video v-for="(item,index) in videoList"
           :ref="item.index"
           :key="item.index"
           :class="{'show':item.index == videoIndex, 'hide': item.index != videoIndex}"
           :src="item.url"
           autoplay="false"
           webkit-playsinline="true"
           playsinline="true"
           x-webkit-airplay="allow"
           x5-video-player-type="h5"
           x5-video-player-fullscreen="true"
           x5-video-orientation="portraint"
           style="object-fit:fill"
           @canplay="canplay($event,item)"
           @ended="ended($event,item)" />

  </div>
</template>
<script>
export default {
  name: "VideoListPlay",
  props: {
    nextIndex: {
      type: String,
      default: "",
    },
    loop: {
      type: Boolean,
      default: true,
    },
  },

  data() {
    return {
      // percentage: 0,
      videoNum: 0,
      // colors: [
      //   { color: "#f56c6c", percentage: 20 },
      //   { color: "#e6a23c", percentage: 40 },
      //   { color: "#5cb87a", percentage: 60 },
      //   { color: "#1989fa", percentage: 80 },
      //   { color: "#6f7ad3", percentage: 100 },
      // ],
      videoIndex: "1_1",
      overVideoList: [],
      videoList: [
        {
          url: "自己去找视频/admin/app/dp-nginx/filestorage/2022-04-22/d560d1ac-3f3b-4e57-9e58-8c855578683e.mp4",
          describe: "默认视频1",
          index: "0_1"  ,
        },
        {
          url: "自己去找视频/admin/app/dp-nginx/filestorage/2022-04-29/4271f726-16a2-4aa2-a34d-f2f8816fd1aa.mp4",
          describe: "默认视频2",
          index: "2_1",
        },
        {
          url: "自己去找视频/admin/app/dp-nginx/filestorage/2022-04-29/5f6db006-4166-4497-8795-578f212d4b3c.mp4",
          describe: "默认视频3",
          index: "3_1",
        },
        {
          url: "自己去找视频/admin/app/dp-nginx/filestorage/2022-04-29/ee7feb40-7f1b-4939-8bfe-9515276e8f02.mp4",
          describe: "默认视频4",
          index: "4_1",
        },
        {
          url: "自己去找视频/admin/app/dp-nginx/filestorage/2022-04-29/eec01134-8c73-4112-a7ef-e394492d3a46.mp4",
          describe: "默认视频5",
          index: "5_1",
        },
      ],
      myvideo: null,
      url: "",
    };
  },
  watch: {
    nextIndex: {
      handler(val) {
        if (val) {
          this.videoIndex = val.split("_time")[0];
          if (this.overVideoList.includes(this.videoIndex)) {
            this.$nextTick(() => {
              this.$refs[this.videoIndex][0].pause();
              this.$refs[this.videoIndex][0].play();
            });
          } else {
            this.$nextTick(() => {
              this.overVideoList.push(this.videoIndex);
              this.$refs[this.videoIndex][0].play();
            });
          }
        }
      },
      immediate: true,
    },
  },
  created() {
    this.percentage = 0;
    this.videoNum = 0;
  },
  mounted() {
    console.log("初始化");
    // setTimeout(() => {
    //   this.$refs["1_1"][0].play();
    // }, 1000);
  },
  destroyed() {},
  methods: {
    ended(e, item) {
      const that = this;
      this.$emit("ended");
      console.log(item.describe + "播放完成");
    },
    canplay(e, item) {
      ++this.videoNum;
      // this.percentage = (this.videoNum / this.videoList.length) * 100;
      // this.$emit("canplay");
      if (this.videoIndex <= this.videoList.length) {
        e.target.pause();
      }
      console.log(item.describe + "预加载完成");
      if (this.videoNum == this.videoList.length) {
        this.$refs[this.videoIndex][0].play();
      }
    },
    // 视频播放时间
    updateTime() {
      const s = this.$refs.video.currentTime; // 获取当前播放时间
      console.log(s + "=======获取当前播放时间");
    },
    pause() {
      console.log("暂停");
      this.myvideo.pause();
    },
    // 视频播放
    play() {},
  },
};
</script>
<style lang="scss" scoped>
.video-bk {
  position: absolute;
      width: 1920px;
    height: 1080px;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  background:url(./img/bg.png) no-repeat center;
  block-size: 1920px 1080px;
  .progress-show {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 999;
  }
  video {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 1920px;
    height: 1080px;
    &.show {
      visibility: visible;
    }
    &.hide {
      visibility: hidden;
    }
    @for $i from 1 through 10 {
      &:nth-child(#{$i}) {
        z-index: ($i + 1);
      }
    }
  }
}
</style>

demo 调用?

<template>
  <div class="app-container">
    <VideoListPlay @ended="ended"
                   :nextIndex='process' />
  </div>
</template>

<script>
import VideoListPlay from "./videoListPlay.vue";
export default {
  name: "VideoTest",
  components: { VideoListPlay },
  data() {
    return {
      process: "1_1",
    };
  },
  created() {},
  methods: {
    ended() {
      ++this.playNum;
      const list = ["1_1", "2_1", "3_1", "4_1", "5_1"];
      const random = Math.floor(Math.random() * 5);
      this.process =
        list[random] + "_time=" + Math.floor(Math.random() * 1000000);
    },
  },
};
</script>
<style lang="scss" scoped>
img {
  width: 100%;
}
</style>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-11 16:21:48  更:2022-05-11 16:22:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 5:52:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码