当前位置: 首页 > news >正文

一、点击视频下载(通过视频url实现);二、点击下载视频按钮,视频以压缩包形式下载(但未实现压缩视频)

一、点击视频下载(通过视频url实现)

<div class="video-list" v-for="(item,index) in videoList" :key="index"><span class="video-title" >{{item.title}}</span><span class="video-content" >{{item.content}}</span><div class="video-show" ><video@click="choseDownload(item.url)"muted="muted"preload="load"autoplay="autoplay"loop="loop"webkit-playsinlineplaysinlinex5-video-player-type="h5"class="efficient-video"style="cursor: pointer;"><source :src="item.url" type="video/mp4"></video></div></div>
  created() {this.videoListSelect();},
// 视频管理分页查询videoListSelect(){let data = {type:2,//查视频管理的所有数据fileType:'v',//v:视频pageNum: 1,pageSize: 8,};let url = '/ArDownLoad/getAllDownLoad';this.$request.post(url, data).then(data =>{this.videoList = data.obj.list;console.log("this.videoList-------", this.videoList)})},
//视频点击时的下载事件choseDownload(url) {fetch(url).then(res => res.blob()).then(blob => {const a = document.createElement('a')const objectUrl = window.URL.createObjectURL(blob)a.download = namea.href = objectUrla.click()window.URL.revokeObjectURL(objectUrl)a.remove()})},

二、点击下载视频按钮,视频以压缩包形式下载(但未实现压缩视频)
直接下载视频文件,并将其以ZIP格式保存

<div class="video-list" v-for="(item,index) in videoList" :key="index"><span class="video-title" >{{item.title}}</span><span class="video-content" >{{item.content}}</span><div class="video-button"><el-button @click="choseDownload(item.url)" color="#73767a"><el-icon style="margin: 0 4px 0 0"><Download /></el-icon>下载</el-button></div><div class="video-show" ><videomuted="muted"preload="load"autoplay="autoplay"loop="loop"webkit-playsinlineplaysinlinex5-video-player-type="h5"class="efficient-video"style="cursor: pointer;"><source :src="item.url" type="video/mp4"></video></div></div>
choseDownload(videoUrl) {// 创建JSZip实例const zip = new JSZip();// 发起请求获取视频文件的Blob数据this.getVideoBlob(videoUrl).then(blob => {// 将视频文件添加到ZIP中,假设视频文件名为'video.mp4'zip.file('video.mp4', blob, { binary: true });// 生成ZIP文件的Blob数据zip.generateAsync({ type: 'blob' }).then(content => {// 使用file-saver保存ZIP文件saveAs(content, 'video.zip');// 提示用户下载完成this.$message.success('视频压缩包下载完成');}).catch(error => {// 压缩或保存失败时的处理this.$message.error('视频压缩包下载失败');});}).catch(error => {// 获取视频Blob数据失败时的处理this.$message.error('获取视频文件失败');});},// 获取视频文件的Blob数据getVideoBlob(url) {return new Promise((resolve, reject) => {const xhr = new XMLHttpRequest();xhr.open('GET', url, true);xhr.responseType = 'blob';xhr.onload = () => {if (xhr.status === 200) {resolve(xhr.response);} else {reject(new Error(`请求视频文件失败: ${xhr.status}`));}};xhr.onerror = () => {reject(new Error('网络错误'));};xhr.send();});},
http://www.lryc.cn/news/330924.html

相关文章:

  • B树、B+树、哈夫曼树
  • 评价指标_Precision(精确率)、Recall(召回率)和Accuracy(准确率)区别和联系
  • 【React】React AJAX
  • vue 移动端弹窗带滚动效果 滚动到底的时候弹窗下的页面会跟着滑动
  • Linux-3 yum和vim
  • 什么是计算机视觉?计算机视觉:从基础到前沿
  • Java中的可变字符串
  • C++多线程:单例模式与共享数据安全(七)
  • 康耐视visionpro-CogAcqFifoTool工具详细说明
  • 静态图片如何生成gif动画?一个网站在线实现
  • Git 实战教程
  • 解决Vue中仓库持久化的问题,不借助插件用原生JS实现仓库持久化。了解仓库的插件机制、监听的时机
  • ajax的优缺点有哪些?
  • 自贡市第一人民医院:超融合与 SKS 承载 HIS 等核心业务应用,加速国产化与云原生转型
  • vue使用iview导航栏Menu activeName不生效
  • 谷粒商城实战(008 缓存)
  • python的相关语法
  • 【面试经典150 | 动态规划】最小路径和
  • 生成式AI的情感实验——AI能否产生思想和情感?
  • 力扣贪心算法--第一天
  • Nginx反向代理和缓存
  • 支持多元AI场景应用,宁畅“NEX AI Lab”开放试用预约中
  • Git 如何合并多个连续的提交
  • k8s 基础入门
  • 【Python项目】AI动物识别工具
  • 逻辑回归(Logistic Regression)详解
  • .vimrc文件的语句语法
  • c语言之函数指针作形参
  • python文件的读取操作
  • 查看并设定【网络适配器】的优先级(跃点数)