欢迎来到代码驿站!

当前位置:首页 >

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

时间:2020-08-18 11:00:07|栏目:|点击:

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实战教程》

上一篇:java启动jar包将日志打印到文本的简单操作

栏    目:

下一篇:R语言ggplot2边框背景去除的实现

本文标题:vue实现移动端input上传视频、音频

本文地址:http://www.codeinn.net/misctech/3692.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有