vue3在页面放一个视频可以开始暂停 全屏?

在 Vue 3 中,你可以使用 <video> 标签来添加视频到页面,并通过 JavaScript 控制视频的播放、暂停和全屏功能。以下是一个示例代码,演示如何在 Vue 3 中实现控制视频的播放、暂停和全屏功能:

html 复制代码
<template>
  <div>
    <video ref="videoPlayer" width="640" height="360">
      <source src="/path/to/your/video.mp4" type="video/mp4">
      Your browser does not support the video tag.
    </video>

    <button @click="togglePlay">{{ isPlaying ? 'Pause' : 'Play' }}</button>
    <button @click="toggleFullScreen">Toggle Full Screen</button>
  </div>
</template>

<script>
import { ref } from 'vue';

export default {
  setup() {
    const videoPlayer = ref(null);
    const isPlaying = ref(false);

    const togglePlay = () => {
      if (videoPlayer.value.paused) {
        videoPlayer.value.play();
        isPlaying.value = true;
      } else {
        videoPlayer.value.pause();
        isPlaying.value = false;
      }
    };

    const toggleFullScreen = () => {
      if (videoPlayer.value.requestFullscreen) {
        videoPlayer.value.requestFullscreen();
      } else if (videoPlayer.value.mozRequestFullScreen) {
        videoPlayer.value.mozRequestFullScreen();
      } else if (videoPlayer.value.webkitRequestFullscreen) {
        videoPlayer.value.webkitRequestFullscreen();
      } else if (videoPlayer.value.msRequestFullscreen) {
        videoPlayer.value.msRequestFullscreen();
      }
    };

    return {
      videoPlayer,
      isPlaying,
      togglePlay,
      toggleFullScreen
    };
  }
};
</script>

在这个示例中,我们首先在 <video> 标签中引入一个视频文件,并添加控制按钮来实现播放、暂停和全屏功能。通过 ref 来获取视频元素的引用,然后在 togglePlay 方法中根据视频的播放状态进行播放和暂停操作,在 toggleFullScreen 方法中实现全屏功能。

请将 /path/to/your/video.mp4 替换为你实际视频文件的路径。需要注意的是,全屏功能可能在不同浏览器下表现不同,需要根据不同浏览器的 API 进行适配。

相关推荐
IT_陈寒3 分钟前
Java 21虚拟线程实战:7个性能翻倍的异步重构案例与避坑指南
前端·人工智能·后端
锅挤4 分钟前
Vue2:小水一下(5)
前端·javascript·html
翻斗花园岭第一爆破手5 分钟前
flutter2:Container的简介与尺寸
java·服务器·前端
我爱学习好爱好爱11 分钟前
Springboot+OSHI+Vue+ECharts 全栈监控系统
vue.js·spring boot·echarts
倔强的小石头_13 分钟前
Python 从入门到实战(十四):Flask 用户认证(给 Web 应用加安全锁,区分管理员与普通用户)
前端·python·flask
be or not to be16 分钟前
前端基础实战笔记:文档流 + 盒子模型
前端·笔记
程序员码歌18 分钟前
短思考第264天,每天复盘5分钟,胜过你盲目努力1整年(2)
前端·后端·ai编程
nono牛18 分钟前
实战项目:设计一个智能温控服务
android·前端·网络·算法
敲敲了个代码7 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
张雨zy9 小时前
Pinia 与 TypeScript 完美搭配:Vue 应用状态管理新选择
vue.js·ubuntu·typescript