gpt4 book ai didi

javascript - 使 xmlhttprequest 同步可用的情况

转载 作者:行者123 更新时间:2023-12-03 16:50:28 26 4
gpt4 key购买 nike

可以简单地将多个同步请求封装为一个异步请求。

例如,下面代码中的“func”参数可以按顺序包含多个同步请求。与使用 DOM 作为对数据进行操作的媒介相比,这应该使您对数据有更多的控制权。 (还有别的办法吗,我好久没用javaScript了)

function asyncModule(func)
{
"use strict";
var t, args;
t = func.timeout === undefined ? 1 : func.timeout;
args = Array.prototype.slice.call(arguments, 1);
setTimeout(function () {
func.apply(null, args);
}, t);
}

现在我的推理一定有问题,因为规范是这样说的:

Synchronous XMLHttpRequest outside of workers is in the process of being removed from the web platform as it has detrimental effects to the end user's experience. (This is a long process that takes many years.) Developers must not pass false for the async argument when the JavaScript global environment is a document environment. User agents are strongly encouraged to warn about such usage in developer tools and may experiment with throwing an InvalidAccessError exception when it occurs. @ https://xhr.spec.whatwg.org/

我认为您会希望不惜一切代价避免请求中的异步,而是在异步函数中包装同步请求。

这是主要问题以及后续问题。

  • 我举的例子有问题吗?

如果不是那么:

  • 强制请求异步如何才是正确的解决方案?

不用说,如果我的任何“主张”完全错误或半真半假,您可以自由揭穿它们。我对此感到困惑,我给你那个。

请记住,我是在终端而不是浏览器中测试 javaScript。我在 GO 编程语言中使用了网络服务器,一切似乎都运行良好。直到我在浏览器中测试代码时,我才得到有关此规范的提示。

最佳答案

此答案已被编辑。

是的,我的推理是错误的!

有两个 Angular 可以考虑。async 在 javascript 中究竟意味着什么?一个异步调用可以阻止另一个异步调用吗?

javascript 中的异步并不意味着脚本将在具有多个调用堆栈的交错/交替进程中运行。它可以更像是一个全局定时延迟/推迟命令,一旦有机会就会完全接管。这意味着异步调用可以是阻塞的,非阻塞的“async:true”部分只是一个基于 xhttprequest 实现方式的“技巧”。

这意味着在 setTimeout 中封装一个同步请求可能会等待一个失败的请求,最终阻塞其他不相关的异步请求,因为“async:true”特性只会根据其状态值执行。

这意味着旧的浏览器支持要求您链接请求或在您需要执行依赖于另一个的多个请求时使用 DOM 作为媒介..呃......

幸运的是,Javascript 现在有了线程。现在我们可以简单地使用线程来同步地获得多个相关请求的干净封装。 (或任何其他后台任务)

简而言之:如果浏览器在工作人员中,则浏览器不应该有任何同步运行请求的问题。浏览器尚未成为操作系统,但它们更接近。

附言这个答案或多或少是因为反复试验。我围绕 firefox 做了一些测试用例,观察到异步请求确实停止了其他异步请求。我只是从那个观察中推断。如果我仍然遗漏了什么,我不会接受我自己的回答。

编辑(再次..)实际上,可以将 xhttp.timeout 与 xhttp.ontimeout 一起使用。参见 Timeout XMLHttpRequest这意味着如果您提取 setTimeout 并将其用作调度程序,则可以从错误请求中恢复。

// Simple example
function runSchedular(s)
{
setTimeout(function() {
if (s.ptr < callQue.length) {
// Handles rescheduling if needed by pushing the que.
s = s.callQue[s.ptr++](s);
} else {
s.ptr = 0;
s.callQue = [];
s.t = 200;
}
runSchedular(s);
}, s.t);
}

关于javascript - 使 xmlhttprequest 同步可用的情况,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34046610/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com