videojs宫格视频选择播放

项目需要四宫格播放视频,而且还要实现点击视频加入播放。

首先,肯定要实现再一个页面上显示多个视频源并播放视频:

<template>
  <div>
    <div v-for="(item,index) in videoList" :key="index"  class="test_two_box">
      <video :id="'myVideo' + item.id" class="video-js">
        <source :src="item.src" type="video/mp4" />
      </video>
    </div>
  </div>
</template>


<script>
export default {
  data() {
    return {
      videoList: [
        {
          id: 0,
          type: 'video/mp4',
          src: '/mp4/1.mp4',
          name:'视频1'
        },
        {
          id: 1,
          type: 'video/mp4',
          src: '/mp4/2.mp4',
          name:'视频2'
        },
        {
          id: 2,
          type: 'video/mp4',
          src: '/mp4/3.mp4',
          name:'视频3'
        },
        {
          id: 4,
          type: 'video/mp4',
          src: '/mp4/4.mp4',
          name:'视频5'
        }
      ]
    }
  },
  mounted() {
    this.videoList.map((item, index) => {
      let myPlayer = this.$video('myVideo' + item.id, {
        //确定播放器是否具有用户可以与之交互的控件。没有控件,启动视频播放的唯一方法是使用autoplay属性或通过Player API。
        controls: true,
        poster: item.cover,
        //自动播放属性,muted:静音播放
        // autoplay: "muted",
        //建议浏览器是否应在<video>加载元素后立即开始下载视频数据。
        preload: "auto",
        //设置视频播放器的显示宽度(以像素为单位)
        width: "300px",
        //设置视频播放器的显示高度(以像素为单位)
        height: "150px"
      });
    })
  }
}
</script>

这样就能显示四个视频,但是四个视频的格式是一列的格式,与我们的目标四宫格不符。

可以在前端展示部分做一个步长2的循环,让每一行都有两个视频:

<template>
  <div>
    <div v-for="(item,index) in videoList" :key="index">
     <ul v-if="index % 2 == 0">
        <video :id="'myVideo' + videoList[index].id" class="video-js">
          <source :src="videoList[index].src" type="video/mp4" />
        </video>
        <video :id="'myVideo' + videoList[index + 1].id" class="video-js">
          <source :src="videoList[index + 1].src" type="video/mp4" />
        </video>
      </ul>
    </div>
  </div>
</template>


<script>
	......
</script>

这样就能实现一个页面四宫格播放四个视频。但是这样只能播放固定的写死的四个视频,怎么实现选择播放哪个呢?

首先,一定获取待播放的全部视频列表showallvideoList。之后可以按钮的方式,选择全部视频列表的某个视频,将其替换正在播放视频列表showvideoList中的某一个视频。至于替换哪一个,可以通过flag的形式标记最早播放的视频,替换后更新flag即可。

但是代码里,播放视频是通过循环建立myPlayer实现的,这种实现方法,只能修改最后一个建立的myPlayer。所以为此要建立四个不同的myPlayer

<template>
	......
</template>
<script>
export default {
  data() {
    return {
      oddflag:true,
      showvideoList: [
        {
          id: 0,
          type: 'video/mp4',
          src: '/mp4/1.mp4',
          name:'视频1'
        },
        {
          id: 1,
          type: 'video/mp4',
          src: '/mp4/2.mp4',
          name:'视频2'
        },
        {
          id: 2,
          type: 'video/mp4',
          src: '/mp4/3.mp4',
          name:'视频3'
        },
        {
          id: 4,
          type: 'video/mp4',
          src: '/mp4/4.mp4',
          name:'视频4'
        }
      ]
      ,
      showallvideoList: [
        {
          id: 0,
          type: 'video/mp4',
          src: '/mp4/1.mp4',
          name:'视频1'
        },
        {
          id: 1,
          type: 'video/mp4',
          src: '/mp4/2.mp4',
          name:'视频2'
        },
        {
          id: 2,
          type: 'video/mp4',
          src: '/mp4/3.mp4',
          name:'视频3'
        },
        {
          id: 3,
          type: 'video/mp4',
          src: '/mp4/4.mp4',
          name:'视频4'
        },
        {
          id: 4,
          type: 'video/mp4',
          src: '/mp4/5.mp4',
          name:'视频5'
        },
        {
          id: 5,
          type: 'video/mp4',
          src: '/mp4/6.mp4',
          name:'视频6'
        }
      ]
    }
  },
  mounted() {

      this.showvideoList.map((item, index) => {
          if(index == 0){
            this.myPlayer0 = this.$video('myVideo' + item.id, {
            //确定播放器是否具有用户可以与之交互的控件。没有控件,启动视频播放的唯一方法是使用autoplay属性或通过Player API。
            controls: true,
            // poster: item.cover,
            //自动播放属性,muted:静音播放
            // autoplay: "muted",
            //建议浏览器是否应在<video>加载元素后立即开始下载视频数据。
            preload: "auto",
            //设置视频播放器的显示宽度(以像素为单位)
            width: "600px",
            //设置视频播放器的显示高度(以像素为单位)
            height: "300px",
          })
        }
        if(index == 1){
            this.myPlayer1 = this.$video('myVideo' + item.id, {
            //确定播放器是否具有用户可以与之交互的控件。没有控件,启动视频播放的唯一方法是使用autoplay属性或通过Player API。
            controls: true,
            // poster: item.cover,
            //自动播放属性,muted:静音播放
            // autoplay: "muted",
            //建议浏览器是否应在<video>加载元素后立即开始下载视频数据。
            preload: "auto",
            //设置视频播放器的显示宽度(以像素为单位)
            width: "600px",
            //设置视频播放器的显示高度(以像素为单位)
            height: "300px",
          })
        }
        if(index == 2){
            this.myPlayer2 = this.$video('myVideo' + item.id, {
            //确定播放器是否具有用户可以与之交互的控件。没有控件,启动视频播放的唯一方法是使用autoplay属性或通过Player API。
            controls: true,
            // poster: item.cover,
            //自动播放属性,muted:静音播放
            // autoplay: "muted",
            //建议浏览器是否应在<video>加载元素后立即开始下载视频数据。
            preload: "auto",
            //设置视频播放器的显示宽度(以像素为单位)
            width: "600px",
            //设置视频播放器的显示高度(以像素为单位)
            height: "300px",
          })
        }
        if(index == 3){
            this.myPlayer3 = this.$video('myVideo' + item.id, {
            //确定播放器是否具有用户可以与之交互的控件。没有控件,启动视频播放的唯一方法是使用autoplay属性或通过Player API。
            controls: true,
            // poster: item.cover,
            //自动播放属性,muted:静音播放
            // autoplay: "muted",
            //建议浏览器是否应在<video>加载元素后立即开始下载视频数据。
            preload: "auto",
            //设置视频播放器的显示宽度(以像素为单位)
            width: "600px",
            //设置视频播放器的显示高度(以像素为单位)
            height: "300px",
          })
        }
      })
  },
  methods:{
    show(item){
      console.log(item)
      if(this.oddflag){
        console.log(this.showvideoList[2])
        this.showvideoList[2] = item

      }
      else{
        console.log(this.showvideoList[3])
        this.showvideoList[3] = item
      }
      this.reshow(this.oddflag)
      this.oddflag = !this.oddflag
    },
    reshow(oddflag){
      console.log(this.showvideoList)
      if(oddflag){
        this.myPlayer2.src({src:this.showvideoList[2].src,type:this.showvideoList[2].type})
      }
      else{
        this.myPlayer3.src({src:this.showvideoList[3].src,type:this.showvideoList[3].type})
      }
      // console.log(this.showvideoList)
      // this.myPlayer.src({src:this.showvideoList[3].src,type:this.showvideoList[3].type})
    }
  }
}
</script>

(本示例实现最后两个视频的选择播放)
这样就可以实现宫格视频选择播放了

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现jsp视频播放宫格,您可以按以下步骤操作: 1. 在jsp页面中添加一个包含四个视频播放器的div容器,设置样式为四宫格布局。 2. 使用HTML5的video标签嵌入四个视频,设置每个视频的src属性为对应视频的URL地址。 3. 使用JavaScript编写代码,实现四个视频的同时播放和暂停,以及点击一个视频时,其他三个视频暂停的功能。 以下是实现四宫格视频播放的示例代码: ```html <!DOCTYPE html> <html> <head> <title>四宫格视频播放</title> <style> .grid-container { display: grid; grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(2, 1fr); grid-gap: 10px; } .grid-item { border: 1px solid #ccc; padding: 10px; } </style> </head> <body> <div class="grid-container"> <div class="grid-item"> <video id="video1" width="320" height="240" controls> <source src="video1.mp4" type="video/mp4"> </video> </div> <div class="grid-item"> <video id="video2" width="320" height="240" controls> <source src="video2.mp4" type="video/mp4"> </video> </div> <div class="grid-item"> <video id="video3" width="320" height="240" controls> <source src="video3.mp4" type="video/mp4"> </video> </div> <div class="grid-item"> <video id="video4" width="320" height="240" controls> <source src="video4.mp4" type="video/mp4"> </video> </div> </div> <script> var video1 = document.getElementById("video1"); var video2 = document.getElementById("video2"); var video3 = document.getElementById("video3"); var video4 = document.getElementById("video4"); video1.addEventListener("play", function() { video2.pause(); video3.pause(); video4.pause(); }); video2.addEventListener("play", function() { video1.pause(); video3.pause(); video4.pause(); }); video3.addEventListener("play", function() { video1.pause(); video2.pause(); video4.pause(); }); video4.addEventListener("play", function() { video1.pause(); video2.pause(); video3.pause(); }); </script> </body> </html> ``` 在上面的示例代码中,我们使用了HTML5的video标签嵌入了四个视频,使用了CSS的grid布局实现了四宫格的布局。同时,使用了JavaScript编写了代码,实现了四个视频的同时播放和暂停,以及点击一个视频时,其他三个视频暂停的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值