vue结合el-upload实现腾讯云视频上传功能


Posted in Javascript onJuly 01, 2020

起因

根据需求要实现一个视频上传功能,之前采用七牛云上传,小点视频没问题,大体积视频比如600M左右,再考虑到网速等其他原因就会花费半个小时左右。

后来分析到不仅要考虑上传时间的问题,更重要的是要考虑用户使用4G 网络的情况,考虑用户的流量,线上的视频,不能不做压缩转码,就放到页面上,视频不是图片,不能甩到 cdn 上就行了。 要考虑视频大小,pc 移动端适配,转码,还有防盗版等问题。

最终决定使用腾讯云上传视频,我的项目是web端上传,参考以下链接

官网链接:cloud.tencent.com/document/product/266/9239#.E6.96.AD.E7.82.B9.E7.BB.AD.E4.BC.A0

在项目中的使用

项目使用vue.js + element-ui el-upload组件

引入sdk:

npm install vod-js-sdk-v6
import TcVod from 'vod-js-sdk-v6'

html代码

//上传
 <el-upload
  ref="upload"
  action="filename" 
  :http-request="httpRequest"
  :show-file-list="false">
  <i v-if="videoFlag == false" class="el-icon-plus avatar-uploader-icon"></i>
 </el-upload>
 
 // 进度条
 <el-progress
   v-if="videoFlag"
   type="circle"
   :percentage="videoUploadPercent"
  ></el-progress>
  • action:上传地址,必填,但我们使用http-request,填任意字符串即可,没有实际意义。
  • http-request:覆盖默认上传行为,我们这里就需要自定义上传行为
  • percentage:进度条进度

js代码

methods:{
 // 视频-自定义地址
  httpRequest(file){
  const _this = this
   // 限制视频格式
   if (["video/mp4", "video/quicktime"].indexOf(file.file.type) == -1) {
    this.$message.error("视频格式有误,上传失败");
    return false;
   }
    // 限制视频小于700M
   const isLt10M = file.file.size / 1024 / 1024 < 700;
   if (!isLt10M) {
    this.$message.error("请上传MP4、MOV格式且不超过700MB的视频哦!");
    return false;
   }
    // 显示进度条从0开始
    _this.videoFlag = true
    this.videoUploadPercent=0
   // 获取视频签名
    const getSignature = async function(){
     return await getuploadsignature({ //这里就是发axios请求
      video_type:'operating_activity' // 参数是和后台定义的,不需要可以不写
     }).then(res => {
       return res
     })
  }

  // 前文中所述的获取上传签名的函数
  const tcVod = new TcVod({
   getSignature:getSignature
   })
  const uploader = tcVod.upload({
   mediaFile: file.file // 这里腾讯云需要获取到file文件里的name,根据你file结构进行填写
  })
  this.uploaderG = uploader // 定义全局用于取消上传

  // 进度
  uploader.on('media_progress', function(info) {
    _this.videoUploadPercent = parseInt(info.percent * 100);
  })

  // 上传成功
  uploader.done().then((doneResult) => {
    _this.videoFlag = false // 关闭进度条
    _this.videoForm.Video = doneResult.fileId // 存储fileId
    // 这里发请求给后端进行转码操作
    const data = {
     file_id:doneResult.fileId, // 腾讯云file_id
     video_type:'operating_activity', // 视频类型
     video_name:'', // 视频名称
     video_url: doneResult.video && doneResult.video.url?doneResult.video.url:'',// 视频地址
    }
    // 腾讯视频转码
    videoProcedure(data)
    .then(res => {
    }).catch(err => {
     console.log(err)
    })
  }).catch( (err) => {
   console.log(err)
  })
}
}

转码需要一定的时间,视频体积越大转码时间越长。
表单提交时将fileId值传给后端,等需要预览视频时,获取fileId后请求后端的视频详情接口,最终播放返回的视频地址即可。

到此这篇关于vue结合el-upload实现腾讯云视频上传功能的文章就介绍到这了,更多相关vue 腾讯云视频上传内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木! 

Javascript 相关文章推荐
javascript与cookie 的问题详解
Nov 11 Javascript
js 针对html DOM元素操作等经验累积
Mar 11 Javascript
jQuery实现限制textarea文本框输入字符数量的方法
May 28 Javascript
JCrop+ajaxUpload 图像切割上传的实例代码
Jul 20 Javascript
Javascript中apply、call、bind的巧妙使用
Aug 18 Javascript
微信小程序 Flex布局详解
Oct 09 Javascript
js实现控制textarea输入字符串的个数,鼠标按下抬起判断输入字符数
Oct 25 Javascript
js实现移动端微信页面禁止字体放大
Feb 16 Javascript
Vue.js 2.x之组件的定义和注册图文详解
Jun 19 Javascript
解决angularjs WdatePicker ng-model的问题
Sep 13 Javascript
vue中的 $slot 获取插槽的节点实例
Nov 12 Javascript
Element Tooltip 文字提示的使用示例
Jul 26 Javascript
详解vue3.0 diff算法的使用(超详细)
Jul 01 #Javascript
mapboxgl区划标签避让不遮盖实现的代码详解
Jul 01 #Javascript
通过angular CDK实现页面元素拖放的步骤详解
Jul 01 #Javascript
微信小程序用户盒子、宫格列表的实现
Jul 01 #Javascript
vue商城中商品“筛选器”功能的实现代码
Jul 01 #Javascript
vue实现购物车列表
Jun 30 #Javascript
vue实现简单图片上传
Jun 30 #Javascript
You might like
php str_pad() 将字符串填充成指定长度的字符串
2010/02/23 PHP
php面向对象中static静态属性和静态方法的调用
2015/02/08 PHP
php设计模式之单例模式代码
2016/06/11 PHP
laravel手动创建数组分页的实现代码
2018/06/07 PHP
laravel实现按月或天或小时统计mysql数据的方法
2019/10/09 PHP
jQuery动画出现连续触发、滞后反复执行的解决方法
2015/01/28 Javascript
JavaScript数据类型详解
2015/04/01 Javascript
谈谈Jquery中的children find 的区别有哪些
2015/10/19 Javascript
使用jquery/js获取iframe父子级、同级获取元素的方法
2016/08/05 Javascript
js 定位到某个锚点的方法
2016/11/19 Javascript
浅谈jquery选择器 :first与:first-child的区别
2016/11/20 Javascript
javascript中json基础知识详解
2017/01/19 Javascript
JS实现批量上传文件并显示进度功能
2017/06/27 Javascript
vue+webpack 打包文件 404 页面空白的解决方法
2018/02/28 Javascript
Angularjs 根据一个select的值去设置另一个select的值方法
2018/08/13 Javascript
[01:04:48]VGJ.S vs TNC Supermajor 败者组 BO3 第一场 6.6
2018/06/07 DOTA
[37:03]完美世界DOTA2联赛PWL S3 INK ICE vs GXR 第二场 12.16
2020/12/18 DOTA
Python多线程编程(八):使用Event实现线程间通信
2015/04/05 Python
python将每个单词按空格分开并保存到文件中
2018/03/19 Python
python获取代理IP的实例分享
2018/05/07 Python
python numpy 显示图像阵列的实例
2018/07/02 Python
python3使用pandas获取股票数据的方法
2018/12/22 Python
python可视化实现代码
2019/01/15 Python
python3发送邮件需要经过代理服务器的示例代码
2019/07/25 Python
GDAL 矢量属性数据修改方式(python)
2020/03/10 Python
使用Pycharm分段执行代码
2020/04/15 Python
Python基于Twilio及腾讯云实现国际国内短信接口
2020/06/18 Python
python 基于opencv 绘制图像轮廓
2020/12/11 Python
pycharm配置安装autopep8自动规范代码的实现
2021/03/02 Python
香港家用健身器材、运动器材及健康美容仪器专门店:FitBoxx
2019/12/05 全球购物
优秀通讯员事迹材料
2014/01/28 职场文书
建筑专业毕业生自荐信
2014/05/25 职场文书
稽核岗位职责范本
2015/04/13 职场文书
立春观后感
2015/06/18 职场文书
pyqt5打包成exe可执行文件的方法
2021/05/14 Python
Mysql忘记密码解决方法
2022/02/12 MySQL