在英特网搜寻了一下,发掘以jquery+ajax方式完毕单张图片上传的代码是一些,但完毕批量上传图片的次序却没寻觅到,于是依照查找到的代码,写了2个得以批量上传的。
先看效能图

图片文件上传,有很各类共谋的,这一次首要讲的是“Content-Type:multipart/form-data;”的花样。

图表上传功用

html结构:

<div id="upload_Img">
       <div id="preview_wrap" style="display: inline-block;">
       </div> 
       <div id="" style="position: relative; width:3rem;height:3rem;display: inline-block;">   
            ![](6f4fbfb7/addimg.png)
            <input id="uploadIMG" type="file" name="pic"/>
       </div>
  </div>

在html中input的type=file就足以兑现文件的上传效能,在其天性中也包蕴三个accept=‘’;能够限制文件的品种,可是在chrom浏览器中会产生非常大的延时,页面给人的认为特别卡顿,由此最佳在js代码中对文本举行项目剖断。input也足以设置属性multiple=“multiple”达成五个文本的上传。在上述的代码中,笔者将input[ajax实现批量上传图片,基于firefox实现ajax图片上传。type=file]的折射率设置成了0
,在用了相对固化relative和z-index的体裁,使用3个图片来效仿增多图片上传的按键。这一次的品种中大家根本是h伍页的上传图片,由此未有增加三个公文上传的功能,也未曾利用ajaxfileupload的插件,就自身入手写了八个效果,首要用到formData类型的变量,将file对象存入在那之中,然后传入后台的接口,在从后台的接口获取重临的图形在图床的链接新闻。主要的js代码如下:


js代码:

 //上传图片预览效果
function ImgPreview(srcImg){
  var preview=$('#preview_wrap');
     var result='<div class="preview">![]('+srcImg+')<a class="del_Img"></a></div>';
     preview.append(result);  
}
 $('#preview_wrap').on('click','.del_Img',function(){
  $(this).parent('div').remove();
  });
$('#uploadIMG').on('change',function(){
     var len=$('.preview').length;
     var picsdata=$('#uploadIMG').val();
     if(len>2){
       jsAlert('最多可以上传3张照片!');
       close();
     }else{
      var _file=document.getElementById("uploadIMG");
      var i=_file.value.lastIndexOf('.');
      var len=_file.value.length;
      var extEndName=_file.value.substring(i+1,len);
      var extName="GIF,BMP,JPG,JPEG,PNG";//首先对格式进行验证
      if(extName.indexOf(extEndName.toUpperCase())==-1){
         jsAlert("请您上传图片");
         close();
        }else{
          console.log(extEndName);
          var picFormData = new FormData();
          var picdata=this.files[0];
          picFormData.append("pic", picdata);
          console.log(picFormData);
          $.ajax({
            type:'POST',
            data:picFormData,
            contentType:false,
            processData:false,
            cache:false,
            url:'http:///feedback/upimg',
            success:function(res){
                 if(res.data.errno==0){
                   var srcImg=res.data.errmsg;
                   ImgPreview(srcImg);}
             }   
      }); 
    }
  }    
});

先是对此图片上传出说,使用ajax只好经过post请求上传图片,无法透过get请求,因而对此ajax的跨域难题,就不能够动用jsonp的不二秘诀来消除,因为jsonp只扶助get请求。自身也是煎熬半天才通过百度的办法找到了开始和结果。理论的学识供给通过施行来证明技艺明了的更为不可开交。此外对于ajax发送formData类型的数目,须要安装多少个必备的参数:

contentType:false,//内容类型设置为false,告诉后台为formData类型
processData:false,//因为是formData类型的参数所以不需要处理
cache:false,//图片不需要缓存

对此预览的兑现极粗略,正是充实壹层div,修改当中的img的src属性,因为本地预览对于h5的页面手机端有bug,具体如何bug小编也并未有考试,同事说图片预览依旧供给接口重返的链接地址相比较可信赖。以上便是本身的多少个小功用的落到实处,也是花了成都百货上千天,在小慧姐的扶助下才成功的,真的很感激啊,出入职场的小白,希望早日能形成一名牛b的程序员,有姿首也可以有实力哈哈哈!

图片 1

在工作中前台一些静态文件是透过FTL模版系统,前台页面通过SSI实行引用的,项目支出的时候就需求扭转大批量的静态SHTML文件了,本来认为应该是后台的事务,可是自打小编进那公司,那快东西就付出了前者~~笔者代表无语,无法就按着习贯来吗,但小编是个懒人,就想着能或不能够透过ajax提交呢

文尾寄语


那是本身先是运用markdown编辑文本,真的很棒哦,相当赞。也是出入职业的率先篇手艺日志,和温馨的工作有关,希望以后的活着能顺顺Lyly,本事能革新,有爱好前端的同伙们得以同步互动学习,本人也许渣渣,还须求大拿们何其来教导教导!

马上要结业了,时间好快,不领会今后的路会是鲜花和掌声照旧满地荆棘,无论怎么着作者都会微笑面临,新的生活就此要拉开帷幕了!期待!激动!

点击扩大开关,会追加一个选拔框,如下图:

据书上说平常对MDN的阅读,后天重视是FormData那么些指标消除多文件上传的协商。

图片 2

慎选要上传的图纸,效果图如下:

有如整个都完美了,可是在File方法,只幸亏chrome品级上本事运作。图片上传无法落实,一般常见文书能够透过Blob对象达成

图片 3

下边通过了部分主意来完毕,三个钻探历程

上传成功如下图:

一.找了半天,U汉兰达L转为File对象的点子,都失利了。。。

图片 4

2.HTML5 File方向

图片 5

a.通过HTML5 File的例子,开始

上边来看代码:
前台html主要代码:

  

复制代码 代码如下:

  在例子里面,打字与印刷 oFR伊夫nt.target.result
只是找到了”四AAQSkZJ奥德赛gABAQEASABIAAD/二wBDAAUDBAQEAwUEBAQFBQ…”

<button id=”SubUpload” class=”ManagerButton”
onClick=”TSubmitUploadImageFile();return
false;”>鲜明上传</button>  
<button id=”CancelUpload” class=”ManagerButton”
onClick=”javascript:history.go(-1);”>取消</button>  
<button id=”AddUpload” class=”ManagerButton”
onClick=”TAddFileUpload();return false;”>增加</button>
<tr><td class=”tdClass”>
图片1:
</td><td class=”tdClass”>
<input name=”” size=”60″ id=”uploadImg1″ type=”file” />
<span id=”uploadImgState1″></span>
</td></tr>

  原本是base6四编码的数据

因为用了JQuery,所以你完全能够把click事件放在js文件中
“增加”按钮js代码:

  看到上边的编码数据,就悟出Blob对象是否支撑啊,代码如下

网站地图xml地图