欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

web前端图片上传(2)

程序员文章站 2022-06-19 23:34:49
今天发现了一种ajax上传图片的方式,是以前没有用过的,首先来说下为什么要用这种方式。是因为原来后台是用的form表单的方式来提交表单数据的。但是觉得呢,这种方式不太好,因为要刷新页面,前台只用控制台看不到传输的参数(如果哪位大神知道怎么看到,请不吝赐教),所以我们就改成了ajax的方式,结果后台老 ......

  今天发现了一种ajax上传图片的方式,是以前没有用过的,首先来说下为什么要用这种方式。是因为原来后台是用的form表单的方式来提交表单数据的。但是觉得呢,这种方式不太好,因为要刷新页面,前台只用控制台看不到传输的参数(如果哪位大神知道怎么看到,请不吝赐教),所以我们就改成了ajax的方式,结果后台老哥说,前端改改就行了,后端不用改。然后我去找到了这种ajax提交表单的方式。废话不多说,直接看代码。

 1 var formdata = new formdata();//首先这里新建一个空对象
 2                     formdata.append("file", document.getelementbyid("file").files[0]);//这里是一个图片的input框,id为file。appen的第一个参数,是后台的传输的字段
 3                     formdata.append("reward_name", reward_name);
 4                     formdata.append("reward_id", reward_id);
 5                     formdata.append("reward_num", reward_num);
 6                     formdata.append("exchange_num", exchange_num);
 7                     $.ajax({
 8                         url:"__root__/index.php/administration/gamemanage/add_icon",
 9                         type:"post",
10                         processdata:false, //这里需要注意,一定要写false,因为有图片,所以不需要序列化
11                         contenttype:false, //这里也是一个需要注意的点。也要写false
12                         data:formdata,
13                         datatype:'json',
14                         success:function(data){
15                             if(data.info=="添加成功"){
16                                 alert(data.info);
17                                 window.reload();
18                             }else{
19                                 alert(data.info);
20                             }
21                         }
22                     });

  这种方法和我上次写的那个是不一样的,这次的方法是直接提交一个文件。我们来看下这种方式的请求头,和一般的ajax是不一样的。请看截图

web前端图片上传(2)

 

里面的参数就是我上面代码中写的参数,大家可以一一对应起来。

  。这是另一种ajax传输base64图片的方式。其实两种方式都是可以的,但是需要看后台怎么选择。毕竟前后台需要合作,哪种方式只需要前后台商量好就行。