获取 JQuery ajax 请求进度的最干净方法是什么?

编程入门 行业动态 更新时间:2024-10-08 06:21:39
本文介绍了获取 JQuery ajax 请求进度的最干净方法是什么?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

在普通的 javascript 中非常简单:只需要​​将回调附加到 {XMLHTTPRequest}.onprogress

In plain javascript is very simple: need just to attach the callback to {XMLHTTPRequest}.onprogress

var xhr = new XMLHttpRequest(); xhr.onprogress = function(e){ if (e.lengthComputable) var percent = (e.loaded / e.total) * 100; }; xhr.open('GET', 'www...', true); xhr.onreadystatechange = function() { ... }; xhr.send(null);

但我正在做一个使用 JQuery 下载 html 数据的 ajax 站点($.get() 或 $.ajax()),我想知道哪个是获取请求进度的最佳方法,以便用一个小进度条显示它,但奇怪的是,我在 JQuery 文档中没有找到任何有用的东西......

but I'm doing an ajax site that download html data with JQuery ($.get() or $.ajax()) and I was wondering which is the best way to get the progress of a request in order to display it with a little progress bar but curiously, I'm not finding anything usefull in JQuery documentation...

推荐答案

$.ajax 类似这样的事情(仅 HTML5):

Something like this for $.ajax (HTML5 only though):

$.ajax({ xhr: function() { var xhr = new window.XMLHttpRequest(); xhr.upload.addEventListener("progress", function(evt) { if (evt.lengthComputable) { var percentComplete = evt.loaded / evt.total; //Do something with upload progress here } }, false); xhr.addEventListener("progress", function(evt) { if (evt.lengthComputable) { var percentComplete = evt.loaded / evt.total; //Do something with download progress } }, false); return xhr; }, type: 'POST', url: "/", data: {}, success: function(data){ //Do something on success } });

更多推荐

获取 JQuery ajax 请求进度的最干净方法是什么?

本文发布于:2023-10-19 17:36:34,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1508270.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:进度   干净   方法   JQuery   ajax

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!