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


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

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

      操作简单,适合小图,以及如果想兼容低版本的ie没办法用此方法

    2.通过form表单提交。

      form表单提交图片会刷新页面,也可以时form绑定到一个隐藏的iframe上,可以实现无刷新提交数据。但是如果想传输多条form表单数据,需要写很多dom,同时还要写iframe,太麻烦。

    目前感觉比较干净的办法就是通过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数据到后台

    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);
              })        
    }

    以下部分是扩展

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

    最近着手的约能人项目,需要上传图片到七牛,但是感觉只是简单的上传图片还需要引七牛的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('已上传该图片');
                }
              })
          },        
  • 相关阅读:
    [数学-构造矩阵]NEFU 1113
    设计模式【1】:原型模式【创建对象】
    XML(五)dom4j增删改查
    小规则让你写出美丽又高效的程序
    jQuery源代码解析(3)—— ready载入、queue队列
    cocos2d-Lua02Lua面向对象
    在Linux下用make指令编译进度条程序。
    JS两日期相减
    java debugger
    tomcat server.xml
  • 原文地址:https://www.cnblogs.com/cjh1111/p/7017295.html
Copyright © 2020-2023  润新知