这次给大家带来ajax怎么使文件与图片异步上传,ajax使文件与图片异步上传的注意事项有哪些,下面就是实战案例,一起来看一下。
大家好,这篇文章我要给大家分享一个网页文件上传功能的代码,希望大家可以有所参考,或者给我提些建议。
众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一个网页的文件上传功能究竟该怎么去设置呢?今天我就以图片上传为例向大家展示文件上传功能的具体步骤。
其实文件上传有两种方法,一种是from表单submit提交,一种是ajax实现异步提交,可是form表单提交有个问题就是每次在上传完成时会刷新界面,不能实现异步上传,所以现在几乎所有网站都采用ajax异步上传,现在我给大家展示ajax异步上传该如何实现。
首先我先创建一个form表单,代码如下:
1 2 3 4 5 6 7 8 9 | <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>
<p class = "con" ></p>
|
登录后复制
创建完成后,首先我们要先拿到用户从本上传的图片的信息,代码如下
1 2 3 4 5 6 7 8 9 10 | var imgs=[];
var fileM=document.querySelector( "#file" );
$( "#file" ).on( "change" , function (){
console.log(fileM.files);
var fileObj=fileM.files[0];
var formData= new FormData();
formData.append( 'file' ,fileObj);
|
登录后复制
这里的formData就是我们现在要的存储文件信息的对象,然后我们需要把它用ajax请求提交给后台:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
var ajax= new XMLHttpRequest();
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){、
var img =$( "<img src='" +obj.msg+ "' alt='' />" );
$( ".con" ).append(img);
imgs.push(obj.msg);
} else {
alert(obj.msg);
}
}
}
}
});
|
登录后复制
然后我们请求成功后,后台肯定要做出相应的处理,并且把图片存到指定的文件夹里,所以相应的PHP应该完成这些操作:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | <?php
header( "Access-Control-Allow-Origin:*" );
header( "Content-type:text/json" );
$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 );
}
?>
|
登录后复制
这样我们就完成了文件上传的所有步骤,如果你想把自己喜欢的图片,上传到自己的网页上,希望这段代码可以帮助到你!
附:如果上传文件时还要附带上你的其它信息,你只需再前端页面请求完成后加上这段代码即可实现:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | $( '#btn' ).on( 'click' , function (){
var infor = $( '#form' ).serializeArray();
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({
url: "http://localhost/phpClass/file-upload/data.php" ,
data:{
parameter :JSON.stringify(stu)
},
success: function (res){
console.log(res.msg);
}
});
});
|
登录后复制
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
jQuery实现异步刷新
jQuery怎样向服务器发出get和post请求
以上是ajax怎么使文件与图片异步上传的详细内容。更多信息请关注PHP中文网其他相关文章!