虚位以待(AD)
虚位以待(AD)
首页 > 网络编程 > AJAX相关 > FormData+Ajax实现上传进度监控

FormData+Ajax实现上传进度监控
类别:AJAX相关   作者:码皇   来源:互联网   点击:

FormData类型其实是在XMLHttpRequest 2级定义的,它是为序列化表以及创建与表单格式相同的数据(当然是用于XHR传输)提供便利。接下来通过本文给大家分享FormData+Ajax实现上传进度监控,需要的朋友一起看看吧

什么是FormData?

FormData对象可以组装一组用 XMLHttpRequest发送请求的键/值对。它可以更灵活方便的发送表单数据,因为可以独立于表单使用。如果你把表单的编码类型设置为multipart/form-data ,则通过FormData传输的数据格式和表单通过submit() 方法传输的数据格式相同;

如何创建一个FormData对象

你可以自己创建一个FormData对象,然后通过调用它的append()方法添加字段,就像这样:

    //实例化一个formData对象var formData = new FormData();
    formData.append("username", "Groucho");
    formData.append("userid", 123456);
    // 数字 123456 会被立即转换成字符串 "123456"// HTML上的 文件类型input[type=file]的文件框,由用户选择formData.append("userfile", fileInputElement.files[0]);
    // JavaScript file-like 对象var content = '<a id="a"><b id="b">hey!</b></a>';
    // 新文件的正文...var blob = new Blob([content], {
    type: "text/xml"}
    );
    formData.append("webmasterfile", blob);

注意:字段 “userfile” 和 “webmasterfile” 都包含一个文件. 字段 “userid” 是数字类型,它将被FormData.append()方法转换成字符串类型(FormData 对象的字段类型可以是 Blob, File, 或者 string: 如果它的字段类型不是Blob也不是File,则会被转换成字符串类型。

使用jQuery的Ajax方法发送FormData数据

    //记录当前时间var time=new Date().getTime();
    //记录当前进度var percentage =null;
    //记录当前上传速度var velocity=null;
    //记录已上传文件字节大小var loaded=0;
    $.ajax({
    url: 'Url', type: "POST", data: formData, contentType: false, // 必须 不设置内容类型 processData: false, // 必须 不处理数据 xhr: function xhr() {
    //获取原生的xhr对象 var xhr = $.ajaxSettings.xhr();
    if (xhr.upload) {
    //添加 progress 事件监听 xhr.upload.addEventListener('progress', function (e) {
    var nowDate = new Date().getTime();
    //每一秒刷新一次状态 if (nowDate - time >= 1000) {
    //已上传文件字节数/总字节数 percentage = parseInt(e.loaded / e.total * 100);
    //当前已传大小(字节数)-一秒前已传文件大小(字节数) velocity = (e.loaded - loaded) / 1024;
    if (percentage >= 99) {
    $(".hintText").html('服务端正在解析,请稍后');
    }
    else {
    //修改上次记录时间及数据大小 time = nowDate;
    loaded = e.loaded;
    }
    }
    else {
    return;
    }
    }
    , false);
    }
    return xhr;
    }
    , success: function success(response) {
    //成功回调 }
    , error: function error(error) {
    //失败回调 }
    }
    );

总结

以上所述是小编给大家介绍的FormData+Ajax实现上传进度监控,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:

  • jQuery+datatables插件实现ajax加载数据与增删改查功能示例
  • ajax请求data遇到的问题分析
  • Servlet获取AJAX POST请求中参数以form data和request payload形式传输的方法
  • 利用 FormData 对象和 Spring MVC 配合实现Ajax文件下载功能
  • vuejs使用FormData实现ajax上传图片文件
  • jQuery.Ajax()的data参数类型详解
  • jQuery Ajax使用FormData上传文件和其他数据后端web.py获取
  • 详解ajax的data参数错误导致页面崩溃
相关热词搜索: ajax 进度监控 formdata 上传进度