ajax实现表单提交

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

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

其实文件上传有两种方法,一种是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({
   data:{
    parameter :JSON.stringify(stu)
   },
   success: function (res){
    console.log(res.msg);
   }
   });
  });

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值