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上传操作汇总》进行学习。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“vue实现移动端input上传视频、音频”评论...
更新动态
2024年12月27日
2024年12月27日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]