ajax实现图片上传和预览

图片上传功能

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[type=file]的透明度设置成了0 ,在用了相对定位relative和z-index的样式,使用一个图片来模仿添加图片上传的按钮。这次的项目中我们主要是h5页的上传图片,因此没有添加多个文件上传的功能,也没有使用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的程序猿,有颜值也有实力哈哈哈!

文尾寄语


这是我第一使用markdown编辑文本,真的很棒哦,很赞。也是出入工作的第一篇技术日志,和自己的工作有关,希望以后的生活能顺顺利利,技术能更上一层楼,有喜欢前端的小伙伴们可以一起相互学习,本人还是渣渣,还需要大牛们多多来指导指导!

马上要毕业了,时间好快,不知道未来的路会是鲜花和掌声还是满地荆棘,无论如何我都会微笑面对,新的生活就此要拉开帷幕了!期待!激动!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,366评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,521评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,689评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,925评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,942评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,727评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,447评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,349评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,820评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,990评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,127评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,812评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,471评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,017评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,142评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,388评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,066评论 2 355

推荐阅读更多精彩内容

  • 基于html5的多图片上传 本文是建立在张鑫旭大神的多文图片传的基础之上.首先先放出来大神多图片上传的博客地址:h...
    cofuMaster阅读 9,206评论 0 13
  • 跨域上传文件 之前解决跨域问题都是使用的JQuery的JSONP类型的Ajax请求,JSONP原理是让服务器把数据...
    Evelynzzz阅读 1,353评论 0 3
  • 背景描述 有这么一个需求:一个表单,有十几个input,一个文件上传的input,可以上传一张图片。 要求上传图片...
    Java_or_PHP阅读 4,542评论 0 5
  • 参考1-HTML5实现图片压缩上传功能参考2-移动前端—图片压缩上传实践参考3-移动端H5图片压缩上传 大体步骤 ...
  • 从小生活在农村,虽然爸爸是公务员,有固定的收入,比起周围的孩子要好些,但大多还是处于物质贫乏的境况中。这基本是我们...
    十里麦田阅读 293评论 4 3