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

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    利用H5特性FormData实现不刷新文件上传

    之前朋友说的不刷新上传文件。最暴力的解决方案就是上网上搜各种JS库,附带多图上传,预览,甚至是图片处理等特技。那么如果不接触第三方的库,可不可以利用ajax来做。就这个问题,有人给出的解决方案是借助iframe,这里就不赘述了。但是Html5是个好东西,他提供了FormData,FormData可以帮助我们拼凑参数,乃至文件资源。这样,我们就可以轻松用$.ajax不刷新上传。当然也不需要iframe。

    代码

    下列是前端部分。

    !DOCTYLE html>
    meta charset=utf->
    head>
    script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/../jquery.min.js">/script>
    /head>
    script type="text/javascript">
    $(function(){
      $('#add').submit(function(){
        var data = new FormData($('#add')[]); 
        console.log(data);
        $.ajax({ 
          url: 'ajax.php', 
          type: 'POST', 
          data: data, 
          dataType: 'JSON', 
          cache: false, 
          processData: false, 
          contentType: false, 
          success:function(data){ 
            //alert(data);
            alert("UploadFile Success");
          }  
        }); 
        return false;  
      });
    });
    /script>
    form id='add'>
    input type="text" name='book'>/input>
    input type="file" name='source'>/input>
    input type="submit">
    /form>

    不多赘述里面的代码,就讲一行代码

    var data = new FormData($('#add')[0]);

    FormData是一个表单对象,他可以将表单对象的表单域分别形成key=>value。那么是不是我们自己再拼接额外的key=>value呢,答案是可以的,详情可以百度FormData。

    还有就是为什么是$('#add')[0]?

    我只能说 js = jQuery[0];

    PHP部分

    ?php 
      header('Content-Type:application/json; charset=utf-8');
      echo json_encode(array($_FILES,$_REQUEST));
    ?>

    这边只是做下测试,如果能看到$_FILES有东西,那么证明我们是可以做上传的。

    测试上传

    可以看到ajax请求到了ajax.php

     

    看下preview,就可以看到返回$_FILES的相关信息了。


    您可能感兴趣的文章:
    • vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理
    • H5上传本地图片并预览功能
    • H5手机端多文件上传预览插件
    • 移动端利用H5实现压缩图片上传功能
    • vue中用H5实现文件上传的方法实例代码
    • H5移动端图片压缩上传开发流程
    • H5图片压缩与上传实例
    • H5移动开发Ajax上传多张Base64格式图片到服务器
    • H5实现手机拍照和选择上传功能
    上一篇:基于h5 ajax实现手机定位(demo)
    下一篇:ajax post方式表单提交setRequestHeader报错解决方法
  • 相关文章
  • 

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

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

    利用H5特性FormData实现不刷新文件上传 利用,特性,FormData,实现,