FormData+Ajax上传进度监控(附代码)

这次给大家带来FormData+Ajax上传进度监控(附代码),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 = 'hey!'; // 新文件的正文...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) {  //失败回调     }});

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

实现无刷新下拉联动的Ajax+Servlet(附代码)

怎样用Ajax异步检查用户名有无重复

以上就是FormData+Ajax上传进度监控(附代码)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2777346.html

(0)
上一篇 2025年3月8日 15:05:02
下一篇 2025年2月26日 08:59:40

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • ajax跨域问题的图文详解(附代码)

    这次给大家带来ajax跨域问题的图文详解(附代码),ajax跨域问题的注意事项有哪些,下面就是实战案例,一起来看一下。 跨域 同源策略限制 同源策略阻止从一个域上加载的脚本获取或操作另一个域上的文档属性。也就是说,受到请求的 URL 的域必…

    2025年3月8日 编程技术
    200
  • ajax数据处理步骤详解(附代码)

    这次给大家带来ajax数据处理步骤详解(附代码),ajax数据处理的注意事项有哪些,下面就是实战案例,一起来看一下。 需要注意的是,调用的封装的数据库,和jQuery的保存地址 一、注册 (1)写文本框来进行用户名的验证 //这个使用来显示…

    2025年3月8日 编程技术
    200
  • vue 实现全选全不选的示例代码_vue.js

    本篇文章主要介绍了vue 实现全选全不选的示例代码,现在分享给大家,也给大家做个参考。一起过来看看吧 全选功能可以说是前端开发中非常常见的一个功能,以前的项目开发用jQuery开发比较多。最近在使用vue前端框架重构之前的项目。从jQuer…

    2025年3月8日
    200
  • JS实现AJAX局部刷新(附代码)

    这次给大家带来JS实现AJAX局部刷新(附代码),JS实现AJAX局部刷新的注意事项有哪些,下面就是实战案例,一起来看一下。 AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),…

    编程技术 2025年3月8日
    200
  • dom4j中使用XPath详解(附代码)

    这次给大家带来dom4j中使用XPath详解(附代码),dom4j中使用XPath的注意事项有哪些,下面就是实战案例,一起来看一下。 如下所示: package com.wzh.test.xpath; import java.io.File…

    编程技术 2025年3月8日
    200
  • Ajax上传并预览图片(附代码)

    这次给大家带来Ajax上传并预览图片(附代码),Ajax上传并预览图片的注意事项有哪些,下面就是实战案例,一起来看一下。 1. 直接上最简单的 一种 ajax 异步上传图片,并预览 html: 图片上传 | cookie file: des…

    编程技术 2025年3月8日
    200
  • $.ajax()的使用方法(附代码)

    这次给大家带来$.ajax()的使用方法(附代码),$.ajax()使用的注意事项有哪些,下面就是实战案例,一起来看一下。 AJAX 是一种与服务器交换数据的技术,可以在补充在整个页面的情况下更新网页的一部分。接下来通过本文给大家介绍aja…

    编程技术 2025年3月8日
    200
  • Ajax异步上传文件实列(附代码)

    这次给大家带来Ajax异步上传文件实列(附代码),Ajax异步上传文件的注意事项有哪些,下面就是实战案例,一起来看一下。 非常不多说,直接给大家上干货,写的不好还请见谅。 具体代码如下所示: Index$(function() {$(‘:b…

    编程技术 2025年3月8日
    200
  • ajax基本通用代码有哪些

    这次给大家带来ajax基本通用代码有哪些,使用ajax基本通用代码的注意事项有哪些,下面就是实战案例,一起来看一下。 本文实例讲述了ajax基本通用代码。分享给大家供大家参考,具体如下: var xmlhttpfunction loadXM…

    编程技术 2025年3月8日
    200
  • react怎样实现页面代码分割和按需加载

    这次给大家带来react怎样实现页面代码分割和按需加载,react实现页面代码分割和按需加载的注意事项有哪些,下面就是实战案例,一起来看一下。 虽然一直有做 react 相关的优化,按需加载、dll 分离、服务端渲染,但是从来没有从路由代码…

    2025年3月8日
    200

发表回复

登录后才能评论