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

发布时间:2022-04-17 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了利用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

&nbsp;

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


脚本宝典总结

以上是脚本宝典为你收集整理的利用H5特性FormData实现不刷新文件上传全部内容,希望文章能够帮你解决利用H5特性FormData实现不刷新文件上传所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: