本文主要为大家详细介绍了ajax实现异步文件(图片)上传功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。
众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一个网页的文件上传功能究竟该怎么去设置呢?今天我就以图片上传为例向大家展示文件上传功能的具体步骤。
其实文件上传有两种方法,一种是from表单submit提交,一种是ajax实现异步提交,可是form表单提交有个问题就是每次在上传完成时会刷新界面,不能实现异步上传,所以现在几乎所有网站都采用ajax异步上传,现在我给大家展示ajax异步上传该如何实现。
首先我先创建一个form表单,代码如下:
创建完成后,首先我们要先拿到用户从本上传的图片的信息,代码如下
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 =$("@@##@@");
$(".con").append(img);
imgs.push(obj.msg);
}else{
alert(obj.msg);
}
}
}
}
});然后我们请求成功后,后台肯定要做出相应的处理,并且把图片存到指定的文件夹里,所以相应的PHP应该完成这些操作:
0,"msg"=>"文件移动成功");
}else{
$infor=array("err"=>1,"msg"=>"文件移动失败");
}
}else{
$infor=array("err"=>1,"msg"=>"文件格式不合法");
}
echo json_encode($infor);
}
?>这样我们就完成了文件上传的所有步骤,如果你想把自己喜欢的图片,上传到自己的网页上,希望这段代码可以帮助到你!
部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/
附:如果上传文件时还要附带上你的其它信息,你只需再前端页面请求完成后加上这段代码即可实现:
//完成form表单数据的提交
$('#btn').on('click',function(){
// serializeArray()将form表单控件中的数据序列化成数组,数组中含有若干对象,对象包含对应控件的name和value
var infor = $('#form').serializeArray();
// console.log(infor);
var stu = {};
for (var i=0;i相关推荐:
php中通过Ajax如何实现异步文件上传的代码实例_php技巧









