vue videojs视频播放插件 动态资源

概览:使用vediojs第三方视频播放插件,视频加载有两种方式,第一种是html方式,类似于img标签的src,写在video标签内的<source src=''>;第二种方式是js方式,实例化一个videojs对象并且赋值src。

一、定义

videojs官网

videojs中文文档

videojs英文文档

gitlab源码

videojs的option的所有的配置参数

二、操作步骤

1.1 安装

pnpm i video.js

pnpm i @types/video.js -D

或者

yarn add ...

或者

npm install --save-dev video.js

1.2 引入挂载

1.全局引入main.js

import VideoPlayer from '@videojs-player/vue'

import 'video.js/dist/video-js.css'

const app = createApp(App)

app.use(VideoPlayer)

2.局部引入

import videojs from 'video.js'

import type { VideoJsPlayerOptions } from 'video.js'  //ts写法需要

import 'video.js/dist/video-js.min.css'

1.3 核心代码

// options简单的一些参数

const options: VideoJsPlayerOptions = {

language: 'zh-CN', // 设置语言

controls: true, // 是否显示控制条

preload: 'auto', // 预加载

autoplay: true, // 是否自动播放

fluid: true, // 自适应宽高

src: props.src // 要嵌入的视频源的源 URL

}

// 1. id video元素或video的id

// 2. options 参数配置

// 3. onReady 回调函数,可选

const videoPlayer = videojs(id, options, onReady)

1.4 整体代码

1.封装成一个带ts的页面组件

<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: stringwidth?: stringheight?: 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.htmlconst options: VideoJsPlayerOptions = {language: 'zh-CN', // 设置语言controls: true, // 是否显示控制条preload: 'auto', // 预加载autoplay: true, // 是否自动播放fluid: false, // 自适应宽高src: props.src, // 要嵌入的视频源的源 URLobjectFit: 'cover', // 同css object-fit,作用于video标签}if (videoRef.value) {// 创建 video 实例videoPlayer = videojs(videoRef.value, options, onPlayerReady)}
}
// video初始化完成的回调函数
const onPlayerReady = () => {}
onMounted(() => {initVideo()
})
watch(() => props.src, (now) => {if (now) {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="scss" scoped>
.w-full {width: 100%;
}
.h-full {height: 100%;
}
</style>

2.不封装,直接使用,分为<template><script><style> 三部分

 

<video-player  :src="options.src" :poster="options.poster" class="video-player "crossorigin="anonymous" :preload="options.preload" playsinline controls :loop="true" :volume="0.6":options="options" @mounted="handleMounted" @ended="ended($event)" @play="play($event)"@pause="pause($event)">
</video-player>
/* videoplayer */
const player = shallowRef(null)
const options = reactive({width: '100vw', // 播放器宽度,默认100vwheight: '200px',  // 播放器高度,默认100vhsrc: '', // 视频地址poster: '', // 视频海报type: 'm3u8', // 视频类型muted: false, // 视频静音autoplay: true,  // 自动播放loop: false, // 循环播放volume: 1,  // 音量大小 0-1preload: 'auto',  // 预加载objectFit: 'cover', // 同css object-fit,作用于video标签currentTime: 0, // 当前播放时间showCurrentTime: false, // 是否在拖动进度条时toast当前时间文字errorText: '播放出错', // 视频error时,toast提示control: true,preferFullWindow: true, //将此设置为true将更改不支持 HTML5 全屏 API 但支持视频元素全屏的设备(即 iPhone)上的全屏行为。播放器将被拉伸以填充浏览器窗口,而不是全屏播放视频
})// 当我们需要给视频增加流体模式时,也可以在mounted阶段
const handleMounted = (payload) => {player.value = payload.playerplayer.value.fluid(true)player.value.aspectRatio('16:9')
}
// 我们还可在播放、暂停、结束进行一些操作,或者当这些操作发生时我们需要做什么
const play = (log) => {// 播放之前做验证,需要验证的则暂停播放if (nowPlayUrlIndex.value !== 0 && !nowVideoIdCheck.value[nowgood_id].code) {player.value.pause()show.value = true} else {show.value = false}
}
const pause = (log) => {// 暂停的时候我们可以跳出广告弹窗}
// 视频播放完 =》 跳转下一个
const ended = (log) => {player.value.src(nextPlayUrl.value)player.value.poster(videoList.value[index].resCover)player.value.load(nextPlayUrl.value)player.value.play(nextPlayUrl.value)
}
.video-js {width: 100%;/*不给高度是因为开启了流体模式自适应*/
}:deep(.vjs-poster img) {object-fit: fill ; /*让封面图片也铺开*/}
/*对原生的播放按钮进行样式修改*/
:deep(.video-js .vjs-big-play-button) {display: none;height: 3em;line-height: 3em;border: none;border-radius: 50%;margin-top: -1.31666em;margin-left: -1.5em;
}

 

 

三、代码实现

1.页面组件使用 封装的组件

<script setup lang="ts">
import MyVideo from './components/MyVideo/index.vue'
</script><template><div><div class="video-container"><MyVideo src="https://media.w3.org/2010/05/sintel/trailer.mp4" /></div></div>
</template><style scoped>
.video-container {width: 800px;height: 600px;
}
</style>

vediojs中文文档的 案例 

四、效果展示

五、其它

1.常用配置

 2.常用方法和事件

 六、动态跟换数据

概览:在vue前端框架里面,跟换数据对应的页面会重新渲染。那么,如果我更改了视频播放的video标签绑定的数据,更改了数据页面会播放其它的资源吗?

1.实现思路:

通过监听,数据发生变化,video组件重新渲染。

我们知道视频加载有两种方式,一是html的标签,二是js赋值。

 

 

2.核心代码:

封装的页面组件里面添加监听。把声明的实例重置,并且重新赋值src。

视频资源跟换:

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

 video组件销毁:核心方法:dispose()

dispose()从播放器中删除所有事件侦听器。删除播放器的DOM元素,所以再次初始化的时候需要我们重新创建标签

 source标签src属性赋值成功,但浏览器未去获得相应的视频。
动态插入source标签,触发浏览器进行重排

v-html 指令 可以输出HTML

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

var myVideoDiv = document.getElementById("myVideoDiv")
myVideoDiv.innerHTML = "<video id='myvideo' class='video-js vjs-default-skin  vjs-big-play-centered' controls preload='auto' style='width: 100%;height: 100%' controlBar='true'><source src="+ this.firstSrc +" style='width: 100%;height: 100%' type='application/x-mpegURL'></video>"

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/52227.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Nginx 15分钟入门

1、反向代理和负载均衡 Nginx 反向代理 负载均衡 如上图&#xff0c;网站初期用户量较少的时候&#xff0c;一台服务器就够用&#xff0c;但是当大量用户注册&#xff0c;那么显然一台机器就不够了&#xff0c;我们把同一个项目部署在3台服务器上&#xff0c;如下图所示。那…

Nginx 高性能内存池 ----【学习笔记】

跟着这篇文章学习&#xff1a; c代码实现一个高性能内存池&#xff08;超详细版本&#xff09;_c 内存池库_linux大本营的博客-CSDN博客https://blog.csdn.net/qq_40989769/article/details/130874660以及这个视频学习&#xff1a; nginx的内存池_哔哩哔哩_bilibilihttps://w…

安科瑞智能仪表在户用光伏,工商业光伏,地面光伏,光电建筑的应用

光伏储能逆变器 应用场景 户用储能&#xff0c;小型工商业储能&#xff0c;微电网储能 功能 1.对电能参数进行采样计量和监测&#xff0c;逆变器或者能量管理系统&#xff08;EMS&#xff09;与之进行通讯&#xff0c;根据实时功率及累计电能实现防逆流、调节发电量、电池充…

项目一:基于stm32的阿里云智慧消防监控系统

若该文为原创文章&#xff0c;转载请注明原文出处。 Hi&#xff0c;大家好&#xff0c;我是忆枫&#xff0c;今天向大家介绍一个单片机项目。 一、简介 智慧消防监控系统&#xff0c;是用于检测火灾&#xff0c;温度&#xff0c;烟雾的监控系统。以 stm32单片机为核心外加 MQ…

AcWing1171. 距离(lcatarjan)

输入样例1&#xff1a; 2 2 1 2 100 1 2 2 1输出样例1&#xff1a; 100 100输入样例2&#xff1a; 3 2 1 2 10 3 1 15 1 2 3 2输出样例2&#xff1a; 10 25 #include<bits/stdc.h> using namespace std; typedef long long ll; const int N2e55; int n,m,x,y,k,r…

selenium 和 chromedriver 使用的一些总结

1 selenium 下载地址 selenium PyPIhttps://pypi.org/project/selenium/ 2 chromedriver 下载地址 &#xff0c;可以下载最新版的 chromedriver ChromeDriver - WebDriver for Chrome - Downloadshttps://chromedriver.chromium.org/downloadsChrome for Testing availabi…

忘掉MacType吧,TtfAutoHint手工删除ttc、ttf字体的hinting,微软雅黑字体更显平滑

Windows的ClearType渲染字体方式&#xff0c;结合臭名昭著的hinting技术使微软雅黑字体备受争议&#xff0c;正所谓&#xff1a;成也hinting&#xff0c;败也hinting。 首先什么是hinting&#xff1f; Hinting 这个词一直都没有中文名称&#xff0c;我用粤语将它音译为“牵挺”…

Spring声明式事务@Transactional的一些问题的测试及求证

1.Spring的声明式事务Transactional问题 前提&#xff1a;有两个方法&#xff0c;a方法对a表做修改操作&#xff0c;b方法对b表做修改操作 a方法调用b方法&#xff0c;然后a方法报错&#xff0c;伪代码如下 public void a() {//数据库修改操作CompensateLogDO compensateLogDO…

《Linux从练气到飞升》No.07 Linux第一个小程序-进度条的实现

&#x1f57a;作者&#xff1a; 主页 我的专栏C语言从0到1探秘C数据结构从0到1探秘Linux菜鸟刷题集 &#x1f618;欢迎关注&#xff1a;&#x1f44d;点赞&#x1f64c;收藏✍️留言 &#x1f3c7;码字不易&#xff0c;你的&#x1f44d;点赞&#x1f64c;收藏❤️关注对我真的…

尚品汇总结一:后台商品管理(面试专用)

项目模块&#xff1a; 后台管理模块 分类管理 平台属性管理 品牌管理 品牌与分类管理 SPU管理&#xff08;销售属性&#xff09; SKU管理&#xff08;上下架&#xff09; 商品详情 购物车 订单 支付 秒杀 登录 &#xff1a;账号密码、手机验证码、微信扫码 手机验…

Docker入门及安装

文章目录 1.Docker概述:1.什么是docker2.为什么使用docker3.docker优点4.docker资源网址 2.Docker安装1.卸载旧版本dorcker(非必要)2.设置Docker仓库安装docker引擎4.启动验证docker卸载docker 3.Docker底层原理1.docker的结构和基本概念2.docker为什么比虚拟机快 1.Docker概述…

【iOS安全】OpenSSH使用

安装OpenSSH 在 Cydia 中直接查找和安装 OpenSSH 使用OpenSSH http://orinchen.github.io/blog/2014/01/15/install-and-use-openssh-on-ios/ 保证PC和iPhone在同一网段下 查看iPhone的IP地址 ssh root10.168.xx.xx 口令默认是alpine 或者也可以使用XShell等集成终端