900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > ajax实现异步文件或图片上传功能

ajax实现异步文件或图片上传功能

时间:2018-07-28 11:07:10

相关推荐

ajax实现异步文件或图片上传功能

web前端|js教程

ajax,图片,文件

web前端-js教程

这篇文章主要为大家详细介绍了ajax实现异步文件(图片)上传功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

phpmyadmin源码安装,vscode 添加字体,ubuntu的ftp,查看tomcat连接,sqlite 教程 输出,金牌邮局的服务器,wp插件配置,手机web 前端框架吗,蜘蛛爬虫技术,php开8k,seo手机关键字排行榜公司,信息网站整站源代码,易语言网页验证码错误,旅游后台管理系统模板,jquery 动态切换页面内容,英文网站管理系统,云播程序源码lzw

大家好,这篇文章我要给大家分享一个网页文件上传功能的代码,希望大家可以有所参考,或者给我提些建议。

工作室业务网源码,vscode 是什么软件,ubuntu 自动登出,修改tomcat 启动变快,易语言sqlite3例程,爬虫+制作,php 判断服务器,冯宗耀seo 课程,网站对接cms,html5 播放 视频 模板lzw

众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一个网页的文件上传功能究竟该怎么去设置呢?今天我就以图片上传为例向大家展示文件上传功能的具体步骤。

易语言cf单机版源码,vscode插件推荐,ubuntu 时间,tomcat 8.0,sqlite wal,qq活动网页设计,独立mysql数据库,阿里云服务器建站视频教程,幻灯片插件,数据可视化前端框架,爬虫 app,php 框架,seo 网站优化,springboot项目案例,aspcms幻灯片调用标签,网站源码出售,手机网页点击拨打电话,discuz 默认模板位置,网站织梦后台一片白,在线支付页面html模板,jsp旅游管理系统源码,程序设计实例lzw

其实文件上传有两种方法,一种是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); }?>

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

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

//完成form表单数据的提交 $(#btn).on(click,function(){// serializeArray()将form表单控件中的数据序列化成数组,数组中含有若干对象,对象包含对应控件的name和value var 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); } }); });

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

相关文章:

AJAX用于判定用户是否注册

完美解决ajax跨域请求下parsererror的错误

用ajax传递json到前台中文出现问号乱码问题的解决办法

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。