• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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.status300||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;iinfor.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异步文件上传与NodeJS express服务端处理
    • Ajax异步上传文件实例代码分享
    • ajax实现文件异步上传并回显文件相关信息功能示例
    • jquery中的ajax异步上传
    • Ajax表单异步上传文件实例代码(包括文件域)
    • 表单上传功能实现 ajax文件异步上传
    • ajax异步实现文件分片上传实例代码
    上一篇:解决微信返回上一页,页面中的AJAX的请求,对Get请求无效的问题
    下一篇:AJAX用于判定用户是否注册
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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