vue实现移动端input上传视频、音频

vue移动端input上传视频、音频,供大家参考,具体内容如下

html部分

<div class="title">现场视频</div>

<div class="upLoad">

<label for="pop_video" id="labelr">

<video id="videoId" controls width="100%"></video>

<input style="display:none;" id="pop_video" type="file" accept="video/*" capture="camcorder" v-on:change="getVideo(event, '2')" name="fileTrans" ref="file" value="">

<div class="inputVideo">上传视频</div>

</label>

</div>

<div class="title">现场音频频</div>

<div class="upLoad">

<label for="pop_audio" id="labelr">

<audio id="audioId" controls width="100%"></audio>

<input style="display:none;" id="pop_audio" type="file" accept="audio/*" capture="camcorder" v-on:change="getAudio(event, '2')" name="fileTrans" ref="file" value="">

<div class="inputAudio">上传音频</div>

</label>

</div>

js部分

getVideo (ev, typer) {

let taht = this

//获取上传文件标签

let filesId = document.getElementById('pop_video');

//获取音频标签

let videoId = document.getElementById('videoId')

//把当前files[0]传给getFileURL方法, getFileURL方法对其做一处理

let url = this.getFileURL(filesId.files[0])

if (url) {

//给video标签设置src

videoId.src = url

}

let formData = new FormData();

formData.append("file", filesId.files[0]);

upload(this.token, formData).then(res => {

console.log(res)

if (res.data.code === 0) {

this.videoURL = res.data.data.url

}

})

console.log(url)

},

getAudio (ev, typer) {

let taht = this

//获取上传文件标签

let filesId = document.getElementById('pop_audio');

//获取音频标签

let audioId = document.getElementById('audioId')

//把当前files[0]传给getFileURL方法, getFileURL方法对其做一处理

let url = this.getFileURL(filesId.files[0])

if (url) {

//给video标签设置src

audioId.src = url

}

let formData = new FormData();

formData.append("file", filesId.files[0]);

upload(this.token, formData).then(res => {

console.log(res)

if (res.data.code === 0) {

this.audioURL = res.data.data.url

}

})

console.log(url)

},

getFileURL (file) {

let getUrl = null

if (window.createObjectURL != undefined) {

//basic

getUrl = window.createObjectURL(file)

} else if (window.URL != undefined) {//window.URL 标准定义

//mozilla(firefox)

//获取一个http格式的url路径,这个时候就可以设置<img>中的显示

getUrl = window.URL.createObjectURL(file)

} else if (window.webkitURL != undefined) {//window.webkitURL是webkit的内核

//webkit or chrome

getUrl = window.webkitURL.createObjectURL(file)

}

return getUrl

//video 标签的 duration属性,获取当前视频的长度

// let duration = videoId.duration

// if (Math.floor(duration) > 60) {

// that.layer.msg('视频不能大于60秒')

// }

},

css部分

#inspect .upLoad {

background-color:#fff;

/* height: 1.5rem; */

text-align: left;

padding: 0.3rem;

}

#inspect .inputVideo {

background-color: #00cc66;

color: #fff;

font-size: 0.32rem;

width: 30%;

height: 0.8rem;

line-height: 0.8rem;

border-radius: 0.4rem;

text-align: center;

margin: 0 auto;

}

#inspect .inputAudio {

background-color: #5cadff;

color: #fff;

font-size: 0.32rem;

width: 30%;

height: 0.8rem;

line-height: 0.8rem;

border-radius: 0.4rem;

text-align: center;

margin: 0 auto;

}

效果图

关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。

更多vue学习教程请阅读专题《vue实战教程》

更多精彩内容请参考专题《ajax上传技术汇总》,《javascript文件上传操作汇总》和《jQuery上传操作汇总》进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是 vue实现移动端input上传视频、音频 的全部内容, 来源链接: utcz.com/p/217543.html

回到顶部