vue結(jié)合el-upload實(shí)現(xiàn)騰訊云視頻上傳功能
起因
根據(jù)需求要實(shí)現(xiàn)一個視頻上傳功能,之前采用七牛云上傳,小點(diǎn)視頻沒問題,大體積視頻比如600M左右,再考慮到網(wǎng)速等其他原因就會花費(fèi)半個小時左右。
后來分析到不僅要考慮上傳時間的問題,更重要的是要考慮用戶使用4G 網(wǎng)絡(luò)的情況,考慮用戶的流量,線上的視頻,不能不做壓縮轉(zhuǎn)碼,就放到頁面上,視頻不是圖片,不能甩到 cdn 上就行了。 要考慮視頻大小,pc 移動端適配,轉(zhuǎn)碼,還有防盜版等問題。
最終決定使用騰訊云上傳視頻,我的項(xiàng)目是web端上傳,參考以下鏈接
官網(wǎng)鏈接:cloud.tencent.com/document/product/266/9239#.E6.96.AD.E7.82.B9.E7.BB.AD.E4.BC.A0
在項(xiàng)目中的使用
項(xiàng)目使用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> // 進(jìn)度條 <el-progress v-if="videoFlag" type="circle" :percentage="videoUploadPercent" ></el-progress>
- action:上傳地址,必填,但我們使用http-request,填任意字符串即可,沒有實(shí)際意義。
- http-request:覆蓋默認(rèn)上傳行為,我們這里就需要自定義上傳行為
- percentage:進(jìn)度條進(jìn)度
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;
}
// 顯示進(jìn)度條從0開始
_this.videoFlag = true
this.videoUploadPercent=0
// 獲取視頻簽名
const getSignature = async function(){
return await getuploadsignature({ //這里就是發(fā)axios請求
video_type:'operating_activity' // 參數(shù)是和后臺定義的,不需要可以不寫
}).then(res => {
return res
})
}
// 前文中所述的獲取上傳簽名的函數(shù)
const tcVod = new TcVod({
getSignature:getSignature
})
const uploader = tcVod.upload({
mediaFile: file.file // 這里騰訊云需要獲取到file文件里的name,根據(jù)你file結(jié)構(gòu)進(jìn)行填寫
})
this.uploaderG = uploader // 定義全局用于取消上傳
// 進(jìn)度
uploader.on('media_progress', function(info) {
_this.videoUploadPercent = parseInt(info.percent * 100);
})
// 上傳成功
uploader.done().then((doneResult) => {
_this.videoFlag = false // 關(guān)閉進(jìn)度條
_this.videoForm.Video = doneResult.fileId // 存儲fileId
// 這里發(fā)請求給后端進(jìn)行轉(zhuǎn)碼操作
const data = {
file_id:doneResult.fileId, // 騰訊云file_id
video_type:'operating_activity', // 視頻類型
video_name:'', // 視頻名稱
video_url: doneResult.video && doneResult.video.url?doneResult.video.url:'',// 視頻地址
}
// 騰訊視頻轉(zhuǎn)碼
videoProcedure(data)
.then(res => {
}).catch(err => {
console.log(err)
})
}).catch( (err) => {
console.log(err)
})
}
}
轉(zhuǎn)碼需要一定的時間,視頻體積越大轉(zhuǎn)碼時間越長。
表單提交時將fileId值傳給后端,等需要預(yù)覽視頻時,獲取fileId后請求后端的視頻詳情接口,最終播放返回的視頻地址即可。
到此這篇關(guān)于vue結(jié)合el-upload實(shí)現(xiàn)騰訊云視頻上傳功能的文章就介紹到這了,更多相關(guān)vue 騰訊云視頻上傳內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue3使用el-upload上傳文件示例詳解
- Vue導(dǎo)入excel文件的兩種方式(form表單和el-upload)
- vue使用el-upload實(shí)現(xiàn)文件上傳功能
- vue項(xiàng)目ElementUI組件中el-upload組件與圖片裁剪功能組件結(jié)合使用詳解
- vue+el-upload實(shí)現(xiàn)多文件動態(tài)上傳
- vue使用Element el-upload 組件踩坑記
- vue使用el-upload上傳文件及Feign服務(wù)間傳遞文件的方法
- vue?elementui?實(shí)現(xiàn)圖片上傳后拖拽排序功能示例代碼
- Vue中圖片上傳組件封裝-antd的a-upload二次封裝的實(shí)例
- Vue el-upload單圖片上傳功能實(shí)現(xiàn)
相關(guān)文章
vue2.0和mintui-infiniteScroll結(jié)合如何實(shí)現(xiàn)無線滾動加載
這篇文章主要介紹了vue2.0和mintui-infiniteScroll結(jié)合如何實(shí)現(xiàn)無線滾動加載,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
vue proxyTable的跨域中pathRewrite配置方式
這篇文章主要介紹了vue proxyTable的跨域中pathRewrite配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
vue-router beforeEach跳轉(zhuǎn)路由驗(yàn)證用戶登錄狀態(tài)
這篇文章主要介紹了vue-router beforeEach跳轉(zhuǎn)路由驗(yàn)證用戶登錄狀態(tài),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12
解決vue項(xiàng)目本地啟動時無法攜帶cookie的問題
這篇文章主要介紹了解決vue項(xiàng)目本地啟動時無法攜帶cookie,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02
vue路由傳參之使用query傳參頁面刷新數(shù)據(jù)丟失問題解析
這篇文章主要介紹了vue路由傳參使用query傳參頁面刷新數(shù)據(jù)丟失問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04
Vue數(shù)據(jù)增刪改查與表單驗(yàn)證的實(shí)現(xiàn)流程介紹
這篇文章主要介紹了Vue數(shù)據(jù)增刪改查與表單驗(yàn)證的實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-10-10
vue使用html2canvas實(shí)現(xiàn)將DOM節(jié)點(diǎn)生成對應(yīng)的PDF
這篇文章主要為大家詳細(xì)介紹了vue如何使用html2canvas實(shí)現(xiàn)將DOM節(jié)點(diǎn)生成對應(yīng)的PDF,文中的示例代碼簡潔易懂,感興趣的小伙伴可以學(xué)習(xí)一下2023-08-08

