- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在我的应用程序中实现了拦截器,它在任何 http 请求上显示微调器,并在收到响应后隐藏。我还为多个 http 调用实现了计数器,以便微调器在最后一次调用后关闭。
但现在在某些情况下,假设我有三个 http 异步调用,并且在我的第二个调用到达拦截器之前得到了第一个调用的响应。由于这种情况,这会导致屏幕上的微调器在打开和关闭时闪烁。
最佳答案
根据我对问题的理解,您的代码“按预期”工作。闪烁不是由您的实现中的错误引起的,而是由“极限情况”引起的:两次连续的 $http
调用,导致您的加载程序屏幕在第一个请求后瞬间关闭完成只是为了在发出第二个请求后不久重新激活。当两个请求足够接近时,这会产生闪烁效果:您的最终用户不知道发出了两个连续请求,他只是看到加载屏幕关闭,但很快又会出现。< br/>在这种情况下,计算打开的请求不能缓解你的问题:当第一个 promise 完成时,第二个 promise 还没有完成:计数器仍然是“一个打开的请求”,所以在 promise 完成后你的逻辑现在检测到有 0 个打开的请求并停止加载屏幕。
出于这些原因,我能想到的唯一可行的解决方案是在加载屏幕上实现一种“关闭延迟”。通过使“加载屏幕关闭”不是立即的,您可以让您的应用有时间启动第二个请求。为了实现这一目标,您有两种选择。
第一个可能是更清晰的一个是在处理微调器的组件中实现“延迟”。修改 .hideSpinner()
方法以在经过一定时间延迟后隐藏微调器,并修改 .displaySpinner()
方法以取消任何挂起的“hideSpinner “称呼。 请注意,如果您使用的微调器组件不是您实现的,因此无法轻易修改,这可能不可行。
第二种方法是在拦截器端工作。您应该已经有一个“结束请求”方法来检查请求计数器是否已返回到 0 并在这种情况下停止加载屏幕您的代码应该类似于(注意,这使用 Typescript):
private startRequest(): void {
// If this is the first request,start the spinner
if (this.requestCount == 0) {
this.loadingOverlayService.start();
}
this.requestCount++;
}
private endRequest(): void {
// No request ongoing, so make sure we don’t go to negative count.
// Should never happen, but it is better to be safe than sorry.
if (this.requestCount == 0)
return;
this.requestCount--;
// If it was the last request, call the service to stop the spinner.
if (this.requestCount == 0) {
this.loadingOverlayService.stop();
}
}
只需在 endRequest 方法上添加一个 setTimeout
延迟。这样,实际的“这是最后一个请求”检查将被延迟,让您的应用程序有时间在微调器关闭之前启动新请求。请注意,这引入了一个新问题:现在任何加载微调器的持续时间都会比要求的多 1Δ,其中 Δ 是您使用的超时。在大多数现实世界的情况下,这实际上不是问题,无论如何您都不希望加载微调器“太快”,以避免在非常短的请求时出现类似的闪烁问题。
您的代码应该如下所示:
private endRequest(): void {
setTimeout(function() {
if (this.requestCount == 0)
return;
this.requestCount--;
if (this.requestCount == 0) {
this.loadingOverlayService.stop();
}
}, 1000);
}
如前所述,现在检查将在请求结束后运行一秒钟。这将为您的第二个请求提供启动时间,并在处理程序检查是否还有其他未决请求等待之前递增计数器。因此,您的加载屏幕应该快速关闭并重新打开,而只是保持打开状态,从而消除闪烁的外观。
PS:还有第三个选项我没有讨论,因为你的帖子给我的印象是它不适用于你的情况,所以我将把它贴在这个脚注中作为对 future 读者的提示.
如果您所有的请求都是预先确定的,这意味着它们可以同时开始(没有请求必须等待前一个请求的结果),您可能能够使用 $q.all()
将它们链接成一个累积 promise 。这可以避免闪烁效果,但需要进一步测试以确保此解决方案符合您的需要。最后,setTimeout
选项可能是最方便的选项,具有最大的努力/成本/质量折衷。
关于angularjs - 在多个 http 调用中处理 Spinner,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49167403/
是否有在非 AngularJS 页面内初始化 AngularJS 应用程序的最佳实践方法?我正在向现有网页添加新功能,需要传入一个参数。具体来说,有一组选项卡,一个新选项卡将启动一个 Angular
找不到这两者之间的区别。 保留其中任何一个来引导我的 Angular 应用程序是否有意义? angular.bootstrap(document,['myApp']); 或者 angularAMD.b
我试图理解 Packpub 的书附带的示例 AngularJS 应用程序。 app.js文件在 client/src/app 下定义文件夹,它的模块定义看起来像 angular.module('app
Angularjs 具有用于表单验证和显示错误消息的强大基础设施。但是,我处于必须在特定场景中向用户显示警告消息的情况。这是我的简单表格的图表 该表单在两个字段上都应用了必需和模式验证。除了此验证之外
我在重试功能正常工作时遇到了一些麻烦,希望能获得一些帮助。我有一个要调用的$ resource,直到出现成功情况或超过最大重试次数为止。 我似乎遇到的问题是,在我的重试函数中,我正在调用另一个prom
我目前正在开发一个 AngularJS 应用程序,我遇到了以下障碍。 当用户提交时,我们有一个 login 页面,我们调用一个 web api 并对用户进行身份验证,我们目前正在使用 claims 身
当范围更新时,指令的属性不会改变,它们仍然保持初始值。我在这里缺少什么? HTML works great works: {{foo}} Javascript (基于首页上的 A
我正在使用 Zurb 的 Foundation 框架修改应用程序以实现响应性和 AngularJS。存在数据显示在带有 ... 的表中的错误有 是根据 Foundation 的响应规则隐藏/显示的。不
在过去的三天里,我一直在搜寻互联网,试图弄清楚当angular注意到div的宽度发生变化时如何使指令运行。 我不断看到相同的示例,说明如何实现此目标,但是它们对我不起作用,我也不知道为什么。 我回到一
我正在使用以下代码尝试汇总 在 Angular ,这在整个作品中,但是小于 0.5 的数字四舍五入为 0。我想 向上取整 每个数字到下一个整数。例如 0.02 应四舍五入为 1 {{((data.Vi
我目前正在尝试以一种能够适当扩展到企业级别的方式来组织我的 Angular 应用程序。但是我发现似乎过度依赖框架内的命名约定,并且试图避免命名冲突是一个真正的问题。 例如,当定义任何 constant
我正在阅读 AngularJS 基础知识,并且喜欢在我的页面中使用它的绑定(bind)功能。所以我可以定义可以在 View 中显示的数据,可以对数据进行更改,以便在 View 中更改它而无需担心。 在
在父 Controller 范围内,我定义了 selectedItem设置为“x”。然后在子范围内,我定义了selectedItem使用 ngModel:
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 5年前关闭。 Improve this questi
如果2个条件为真,我试图将一个特定的类应用于li元素,因此我编写了以下代码,但似乎无法正常工作 ng-class="{current:isActive('/'), loginStatus: false
请看看朋克。 http://plnkr.co/edit/DuTFYbLVbPkCIvRznYjG?p=preview ng-pattern regEx不适用于输入文本字段。 仅在需要验证的情况下才能正
我正在为iOS + Android构建AngularJS(1.x)和Ionic/Cordova移动应用程序。我想在登录页面上添加/创建“深层链接”,以便在我向新用户发送“确认您的电子邮件”电子邮件时,
angularjs 中服务(或工厂)的生命周期是什么,何时重新初始化? 最佳答案 当 Angular 启动时,它会将服务的构造函数附加到关联的模块上。这种情况发生一次。 angular .modu
我对 Angular 很陌生,所以希望我知道的足够多,可以问什么似乎是合理的设计问题。 我正在通过 Angular 绘制一些数据,并且正在使用 $resource。在将 Angular 引入项目之前,
我需要在我的 angular-breeze 应用程序中使用国家/地区下拉菜单,我尝试了以下操作: https://github.com/banafederico/angularjs-country-s
我是一名优秀的程序员,十分优秀!