ajax实现异步文件或图片上传功能
发布时间 - 2026-01-10 22:29:14 点击率:次大家好,这篇文章我要给大家分享一个网页文件上传功能的代码,希望大家可以有所参考,或者给我提些建议。

众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一个网页的文件上传功能究竟该怎么去设置呢?今天我就以图片上传为例向大家展示文件上传功能的具体步骤。
其实文件上传有两种方法,一种是from表单submit提交,一种是ajax实现异步提交,可是form表单提交有个问题就是每次在上传完成时会刷新界面,不能实现异步上传,所以现在几乎所有网站都采用ajax异步上传,现在我给大家展示ajax异步上传该如何实现。
首先我先创建一个form表单,代码如下:
<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
//解决跨域问题
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<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文件上传
# ajax异步文件上传
# ajax图片上传
# 图片异步上传
# 更新实例
# ajax 异步上传带进度条视频并提取缩略图
# Ajax异步文件上传与NodeJS express服务端处理
# Ajax异步上传文件实例代码分享
# ajax实现文件异步上传并回显文件相关信息功能示例
# jquery中的ajax异步上传
# Ajax表单异步上传文件实例代码(包括文件域)
# 表单上传功能实现 ajax文件异步上传
# ajax异步实现文件分片上传实例代码
# 表单
# 文件上传
# 上传
# 是一个
# 放在
# 这段
# 自己喜欢
# 自己的
# 的是
# 如果你
# 我要
# 给我
# 完成后
# 有个
# 只需
# 各大
# 去找
# 给大家
# 到你
# 我给
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Python自然语言搜索引擎项目教程_倒排索引查询优化案例
Swift中switch语句区间和元组模式匹配
Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】
Laravel如何使用Blade组件和插槽?(Component代码示例)
Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程
jQuery validate插件功能与用法详解
js代码实现下拉菜单【推荐】
网页设计与网站制作内容,怎样注册网站?
微信小程序 input输入框控件详解及实例(多种示例)
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
油猴 教程,油猴搜脚本为什么会网页无法显示?
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
长沙企业网站制作哪家好,长沙水业集团官方网站?
Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】
如何正确下载安装西数主机建站助手?
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
详解jQuery中基本的动画方法
Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程
Laravel怎么连接多个数据库_Laravel多数据库连接配置
Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤
Laravel DB事务怎么使用_Laravel数据库事务回滚操作
EditPlus中的正则表达式 实战(4)
常州企业网站制作公司,全国继续教育网怎么登录?
如何挑选高效建站主机与优质域名?
Python结构化数据采集_字段抽取解析【教程】
动图在线制作网站有哪些,滑动动图图集怎么做?
Laravel项目怎么部署到Linux_Laravel Nginx配置详解
如何快速重置建站主机并恢复默认配置?
中国移动官方网站首页入口 中国移动官网网页登录
如何确保FTP站点访问权限与数据传输安全?
谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
如何用免费手机建站系统零基础打造专业网站?
Python文件异常处理策略_健壮性说明【指导】
如何在局域网内绑定自建网站域名?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
Mybatis 中的insertOrUpdate操作
创业网站制作流程,创业网站可靠吗?
Laravel如何处理CORS跨域请求?(配置示例)
Laravel如何使用Livewire构建动态组件?(入门代码)
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
如何在阿里云虚拟服务器快速搭建网站?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
EditPlus中的正则表达式实战(6)
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
个人摄影网站制作流程,摄影爱好者都去什么网站?
Laravel如何优化应用性能?(缓存和优化命令)

