<form action=\"大众\"大众 id=\"大众form\"大众>用户名:<input type=\公众text\公众 name=\公众user\公众/></br>密码:<input type=\"大众password\公众 name=\"大众pass\"大众 /></br>性别:<input type=\"大众radio\公众 name=\"大众sex\公众 value=\"大众男\公众/>男<input type=\公众radio\公众 name=\"大众sex\"大众 value=\"大众女\公众/>女头像:<input type=\"大众file\公众 id=\公众file\公众 name=\公众file\"大众/></br><button id=\"大众btn\"大众 type=\"大众button\"大众>提交</button></form><div class=\"大众con\公众></div>

创建完成后,首先我们要先拿到用户从本上传的图片的信息,代码如下

var imgs=[];//存储图片链接//为文件上传添加change事宜var fileM=document.querySelector(\"大众#file\"大众);$(\"大众#file\"大众).on(\"大众change\"大众,function(){console.log(fileM.files);//获取文件工具,files是文件选取控件的属性,存储的是文件选取控件选取的文件工具,类型是一个数组var fileObj=fileM.files[0];//创建formdata工具,formData用来存储表单的数据,表单数据时以键值对形式存储的。
var formData=new FormData();formData.append('file',fileObj);

这里的formData便是我们现在要的存储文件信息的工具,然后我们须要把它用ajax要求提交给后台:

//创建ajax工具var ajax=new XMLHttpRequest();//发送POST要求ajax.open(\"大众POST\公众,\公众http://localhost/phpClass/file-upload/move_file.php\"大众,true);ajax.send(formData);ajax.onreadystatechange=function(){if (ajax.readyState == 4) {if (ajax.status>=200 &&ajax.status<300||ajax.status==304) {console.log(ajax.responseText);var obj=JSON.parse(ajax.responseText);alert(obj.msg);if(obj.err == 0){、//上传成功后自动动创建img标签放在指定位置var img =$(\"大众<img src='\公众+obj.msg+\公众' alt='' />\"大众);$(\"大众.con\公众).append(img);imgs.push(obj.msg);}else{alert(obj.msg);}}}}});

然后我们要求成功后,后台肯定要做出相应的处理,并且把图片存到指定的文件夹里,以是相应的PHP该当完成这些操作:

php获取ajax图片用ajax实现图片上传 React

<?php//办理跨域问题header(\"大众Access-Control-Allow-Origin:\"大众);//解释向前台返回的数据类型为JSONheader(\"大众Content-type:text/json\公众);//$_FILES超全局变量存储是文件数据,是一个关联数组$fileObj=$_FILES['file'];var_dump($fileObj);if($fileObj[\"大众error\公众]==0){//判断文件是否合法$types=[\"大众jpg\"大众,\公众jpeg\"大众,\"大众png\公众,\"大众gif\公众];$type = explode(\"大众/\公众, $fileObj[\公众type\"大众])[1];if(in_array($type, $types)){$time = time();//获取韶光戳 返回一个整形//获取文件详细路径$filePath=\公众http://localhost/phpClass/image1\公众.$time.\"大众.\"大众.$type;echo $filePath;//移动文件$res=move_uploaded_file($fileObj[\"大众tmp_name\"大众],\公众../image1/\"大众.$time.\公众.\"大众.$type);if($res){$infor=array(\"大众err\公众=>0,\"大众msg\"大众=>\公众文件移动成功\"大众);}else{$infor=array(\"大众err\"大众=>1,\"大众msg\"大众=>\公众文件移动失落败\"大众);}}else{$infor=array(\"大众err\"大众=>1,\"大众msg\"大众=>\"大众文件格式不合法\"大众);}echo json_encode($infor);}?>

这样我们就完成了文件上传的所有步骤,如果你想把自己喜好的图片,上传到自己的网页上,希望这段代码可以帮助到你!

附:如果上传文件时还要附带上你的其它信息,你只需再前端页面要求完成后加上这段代码即可实现:

//完成form表单数据的提交$('#btn').on('click',function(){// serializeArray()将form表单控件中的数据序列化成数组,数组中含有多少工具,工具包含对应控件的name和valuevar infor = $('#form').serializeArray();// console.log(infor);var stu = {};for (var i=0;i<infor.length;i++) {var obj=infor[i];stu[obj.name] = obj.value;}stu[\公众imgs\"大众] = imgs;stu[\"大众imgs\公众] = imgs[0];//发送ajax要求$.ajax({url:\公众http://localhost/phpClass/file-upload/data.php\"大众,data:{parameter :JSON.stringify(stu)},success:function(res){console.log(res.msg);}});});

1:先说我们平时打仗到的接口都是后台须要你给他通报几个参数,你就把参数对应的值 给他们就行了

eg:

上面的这个截图便是我们最常用的接口形式飒飒;

2.当你给后台传图片时,你传的是一个文件 而不再是普通的string类型的值。
而是file类型 也便是文件类型

我这里说的是用ajax实现的图片上传

1.在ajax中加上processData : false,

2.在ajax中加上contentType : false,

3.在ajax中加上async:false,

4.紧张是改变ajax中的data这个属性:看代码