axios上传图片(及vue上传图片到七牛))

浏览器上传图片到服务端,我用过两种方法:html

1.本地图片转换成base64,而后经过普通的post请求发送到服务端。vue

  操做简单,适合小图,以及若是想兼容低版本的ie没办法用此方法ios

2.经过form表单提交。axios

  form表单提交图片会刷新页面,也能够时form绑定到一个隐藏的iframe上,能够实现无刷新提交数据。可是若是想传输多条form表单数据,须要写不少dom,同时还要写iframe,太麻烦。api

目前感受比较干净的办法就是经过axios的post请求,发送form数据到后台。浏览器

html部分,至于界面优化,能够把input file的opacity设置为0,点击其父容器,即触发file服务器

<input class="file" name="file" type="file" accept="image/png,image/gif,image/jpeg" @change="update"/>

axios的post请求,发送form数据部分,这样就能够无刷新的提交form数据到后台app

update(e){
          let file = e.target.files[0];           
          let param = new FormData(); //建立form对象
          param.append('file',file,file.name);//经过append向form对象添加数据
          param.append('chunk','0');//添加form表单中其余数据
          console.log(param.get('file')); //FormData私有类对象,访问不到,能够经过get判断值是否传进去
          let config = {
            headers:{'Content-Type':'multipart/form-data'}
          };  //添加请求头
          this.axios.post('http://upload.qiniu.com/',param,config)
          .then(response=>{
            console.log(response.data);
          })        
}

如下部分是扩展dom

vue开发环境下,上传图片到七牛post

最近着手的约能人项目,须要上传图片到七牛,可是感受只是简单的上传图片还须要引七牛的js,太麻烦了,就本身一切从简。实现逻辑:获取后台返回的七牛token,而后axios的post请求,发送form数据到七牛。

 七牛的token是其平台封装好的,直接在本身服务器配置就能获取到 在其官网上能够找到直接能用的代码  ,在七牛平台获取到后,返回给前台直接拿就行了

如下是直接上传图片到七牛,不须要安装七牛乱七八糟的js,只须要经过七牛的form表单上传就好了。

 update(e){
          let file = e.target.files[0];
          let d = new Date();
          let type = file.name.split('.');
          let tokenParem = {
              'putPolicy':'{\"name\":\"$(fname)\",\"size\":\"$(fsize)\",\"w\":\"$(imageInfo.width)\",\"h\":\"$(imageInfo.height)\",\"hash\":\"$(etag)\"}',
              'key':'orderReview/'+d.getFullYear()+'/'+(d.getMonth()+1)+'/'+d.getDate()+'/'+d.valueOf()+'.'+type[type.length-1],
              'bucket':this.bucket,//七牛的地址,这个是你本身配置的(变量)
          };
          let param = new FormData(); //建立form对象
          param.append('chunk','0');//断点传输
          param.append('chunks','1');
          param.append('file',file,file.name)
          console.log(param.get('file')); //FormData私有类对象,访问不到,能够经过get判断值是否传进去
          let config = {
            headers:{'Content-Type':'multipart/form-data'}
          };
       //先从本身的服务端拿到token
          this.axios.post(api.uploadToken,qs.stringify(tokenParem))
            .then(response=>{
                this.token = response.data.uploadToken;
                param.append('token',this.token);
                if(this.images.length>8){
                    alert('不能超过9张');
                    return;
                }
                this.uploading(param,config,file.name);//而后将参数上传七牛
                return;
            })
      },
      uploading(param,config,pathName){
        this.axios.post('http://upload.qiniu.com/',param,config)
          .then(response=>{
            console.log(response.data);
            let localArr = this.images.map((val,index,arr)=>{
              return arr[index].localSrc;
            })
            if(!~localArr.indexOf(pathName)){
              this.images.push({'src':this.showUrl+response.data.key,'localSrc':pathName});
            }else{
                alert('已上传该图片');
            }
          })
      },        
相关文章
相关标签/搜索