ajax异步表单提交图片上传,ajax实现异步文件或图片上传功能

这篇文章主要为大家详细介绍了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应该完成这些操作:

//解决跨域问题

header("Access-Control-Allow-Origin:*");

//说明向前台返回的数据类型为JSON

header("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和value

var infor = $('#form').serializeArray();

// console.log(infor);

var stu = {};

for (var i=0;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);

}

});

});

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值