主页 > 知识库 > 利用H5特性FormData实现不刷新文件上传

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

热门标签:Mysql连接数设置 银行业务 电子围栏 团购网站 阿里云 Linux服务器 服务器配置 科大讯飞语音识别系统

之前朋友说的不刷新上传文件。最暴力的解决方案就是上网上搜各种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特性FormData实现不刷新文件上传》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266