vue实现移动端input上传视频、音频
更新时间:2020年8月18日 13:31 点击:2763
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实战教程》
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持猪先飞。
上一篇: openlayers4实现点动态扩散
下一篇: React冒泡和阻止冒泡的应用详解
相关文章
- 这篇文章主要介绍了vue中activated的用法,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下...2021-01-03
基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传插件功能
这篇文章主要介绍了基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传插件,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-02-23Antd-vue Table组件添加Click事件,实现点击某行数据教程
这篇文章主要介绍了Antd-vue Table组件添加Click事件,实现点击某行数据教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-17- 这篇文章主要介绍了Vue基于localStorage存储信息代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-11-16
- 这篇文章主要介绍了vue 实现动态路由的方法,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下...2020-07-06
- 这篇文章主要介绍了vue 监听 Treeselect 选择项的改变操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-01
- 这篇文章主要介绍了Vue组件跨层级获取组件操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-07-28
- 这篇文章主要介绍了vue 获取到数据但却渲染不到页面上的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-19
antdesign-vue结合sortablejs实现两个table相互拖拽排序功能
这篇文章主要介绍了antdesign-vue结合sortablejs实现两个table相互拖拽排序功能,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-01-09vuejs element table 表格添加行,修改,单独删除行,批量删除行操作
这篇文章主要介绍了vuejs element table 表格添加行,修改,单独删除行,批量删除行操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-07-18- 这篇文章主要介绍了vue treeselect获取当前选中项的label实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-01
- 这篇文章主要给大家介绍了关于Vue中slot-scope的深入理解,这个教程非常适合初学者,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-04-17
- 最常见的多环境配置,就是开发环境配置,和生产环境配置,本文主要介绍了vue项目多环境配置的实现,感兴趣的可以了解一下...2021-07-20
vue项目页面嵌入代码块vue-prism-editor的实现
这篇文章主要介绍了vue项目页面嵌入代码块vue-prism-editor的实现,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-10-30- 本文章来人大家介绍一个php文件上传类的使用方法,期望此实例对各位php入门者会有不小帮助哦。 简介 Class.upload.php是用于管理上传文件的php文件上传类, 它可以帮...2016-11-25
- 这篇文章主要介绍了Vue 3.0 中 jsx 语法使用,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下...2020-11-13
vue Treeselect下拉树只能选择第N级元素实现代码
这篇文章主要介绍了vue Treeselect下拉树只能选择第N级元素实现代码,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-01解决vue的router组件component在import时不能使用变量问题
这篇文章主要介绍了解决vue的router组件component在import时不能使用变量问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-07-27Ant design vue table 单击行选中 勾选checkbox教程
这篇文章主要介绍了Ant design vue table 单击行选中 勾选checkbox教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-10-25- 又码了一个周末的代码,这次在做一些关于文件上传的东西。(PHP UPLOAD)小有收获项目是一个BT种子列表,用户有权限上传自己的种子,然后配合BT TRACK服务器把种子的信息写出来...2016-11-25