ajax实现表单提交
来源:互联网 发布:最新php环境搭建 编辑:程序博客网 时间:2024/06/09 14:39
大家好,这篇文章我要给大家分享一个网页文件上传功能的代码,希望大家可以有所参考,或者给我提些建议。
众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一个网页的文件上传功能究竟该怎么去设置呢?今天我就以图片上传为例向大家展示文件上传功能的具体步骤。
其实文件上传有两种方法,一种是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);
}
});
});
阅读全文
0 0
- 表单提交ajax实现
- ajax实现表单提交
- ajax实现表单的提交
- Ajax实现提交form表单
- 表单上传文件提交实现ajax方式
- 实现ajax提交表单,页面不跳转
- Ajax实现无刷新表单提交
- jQuery实现Ajax方式提交表单
- 简单的超链接实现表单ajax提交
- ajax中如何实现异步提交表单
- ajax实现表单的异步提交
- ajax实现表单提交不跳转
- ajax(三) ajax提交表单、ajax实现文件上传
- ajax(三) ajax提交表单、ajax实现文件上传
- Ajax表单提交实例
- Ajax表单提交实例
- Ajax表单提交实例
- ajax提交表单
- 非科班出身的程序员,该如何弥补技术差距?
- Shader编程学习笔记(九)—— Cg语言入门1
- DELPHI中不同类型的动态数组变量共享内存
- 解决底部弹窗高度最高为半个屏幕高度,变动数据出现非半屏的bug
- Dlib学习笔记:解决dlib array2d转 OpenCV Mat时颜色失真
- ajax实现表单提交
- 定点数与浮点数
- Mysql 按时间段生成每天数据
- 关于Android热修复的几种解决方案
- 利用css3实现箭头
- 读入与输出
- Shader编程学习笔记(十)—— Cg语言入门2
- load 和 initialize
- error C2338: /RTCc rejects conformant code错误解决