- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个操作导致应用程序挂起几秒钟。我想添加某种加载指示器来表明它正在做某事,而不仅仅是卡住。
我已经尝试过一些事情,其中一些是我认为行不通的完整实验。
首先,这是我在尝试添加任何类型的指标之前所得到的:
filterObserver: function(){
// we needed the debounce because it would crash the app if it took too long
// it has to filter through ~10,000 records
Ember.run.debounce(this, this.filterFoo, 1500);
}.observes('filterValue'),
我认为这会起作用,但它似乎要等到观察者中的所有内容都完成后才会重新渲染页面:
controller.js
isLoading: false,
filterObserver: function(){
this.set('isLoading', true);
Ember.run.debounce(this, this.filterFoo, 1500);
this.set('isLoading', false);
}.observes('filterValue'),
模板.hbs
<ul class="project-list {{if isLoading 'loading'}}">
{{#each group in foo}}
{{group-item group=group}}
{{/each}}
</ul>
所以,我想也许我需要强制它重新渲染才能显示更改。我将整个列表移至组件中,以便访问该组件的 rerender
方法:
组件.js
export default Ember.Component.extend({
loadingObserver: function() {
this.rerender();
Ember.run.schedule('afterRender', this, function() {
this.sendAction('filterAll');
});
}.observes('isLoading')
});
controller.js
actions: {
filterAll: function() {
Ember.run.debounce(this, this.filterActivities, 1500);
this.set('isLoading', false);
}
}
所以,我想也许 Ember 的运行循环会起作用。此时,我非常沮丧,但我想尝试一切可能有效的方法:
组件.js
export default Ember.Component.extend({
loadingObserver: function() {
this.rerender();
Ember.run.schedule('afterRender', this, function() {
this.sendAction('filterAll');
});
}.observes('isLoading')
});
这些都不起作用。
我知道不同的路由方法,例如 afterModel
、destroy
等。此时我的页面已经加载,因此在这种情况下这些方法都不起作用。
我相信这是因为 Ember 会等到观察器中的所有内容都完成后才会重新渲染模板。因此,我需要某种方法让它在模板中发生任何更改时显示此指示器,或者等待它完成设置变量并添加类,然后再继续执行操作的代码。
想法?有想法吗?
根据记录,我知道 1.13 引入了 glimmer,这将有助于应用程序挂起。然而,我们依赖的几个插件仍然使用 1.11,所以恐怕我们暂时只能使用它。
最佳答案
编辑
显然run.later
仅适用于我的情况,因为我也使用run.debounce
。下面的代码在我的特定情况下不起作用,因为 run.next
认为 run.debounce
代码已完成,但实际上并未完成。这应该适用于大多数情况:
Ember.run.once(this, function() {
this.set('isLoading', true);
});
Ember.run.next(this, function() {
// your code here
// `isLoading` will be true while this is running,
// so your loading indicator will still be present
this.set('isLoading', false);
});
如果您需要一个在 Ember 的运行循环之外运行的指示器,我原来的答案仍然有效。但是,您可能在绝大多数情况下都可以使用上面的代码。
<小时/>原始答案
我实际上能够解决这个问题。我只是使用 Ember.run.later
来让 Ember 等待所有其他异步事件结束。在我的应用程序中,这相当于:
var _this = this;
this.set('isLoading', true);
Ember.run.debounce(this, this.filterFoo, 1500);
Ember.run.later(function() {
_this.set('isLoading', false);
}, 1500); // I set the timeout to 1500 ms because that's the same as the debounce
我在 Ember 的指南中发现了这个:A SPINNING BUTTON FOR ASYNCHRONOUS ACTIONS 。您可以在 Ember's docs 中阅读有关 run.later
的更多信息。 .
如果我不这样做,它会尝试立即执行所有代码。这基本上只是让它等待,直到完成或超时。
关于javascript - 每当应用程序停止时添加加载指示器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31862471/
我刚刚编辑了现有的指标脚本之一,并向其添加了警报功能,而没有中断脚本的其他部分。然而,当我将修改后的脚本添加到图表中时,TradingView 立即重定向到原始脚本/指标。有谁知道这可能是什么问题吗?
我刚刚编辑了现有的指标脚本之一,并向其添加了警报功能,而没有中断脚本的其他部分。然而,当我将修改后的脚本添加到图表中时,TradingView 立即重定向到原始脚本/指标。有谁知道这可能是什么问题吗?
我对在我的 Silverlight 应用程序中包含一个“throbber”很感兴趣,但由于它是如此常见,我想下载一个或遵循一些简单的教程。你能推荐一个可以在这方面指导我的网站,或者可以提供一个供我下载
我正在使用 RAD Studio 4 C++ 构建器,并希望在我的数据源从数据库中获取数据时显示一个指示轮。我知道 FireMonkey 有一个 Indicator wheel 但 c++ build
我正在努力使用 Android ToggleButton,因为我试图更改绿色指示灯。在 Android SDK 文件夹中,我找到了文件 drawable\btn_toggle_bg.xml ,它说
如何在 Android 中显示 Activity 指示器?是否有任何 Android 库给定的方法?如果不是,请告诉我在 Android 中用于显示 Activity 指示器的技术? 最佳答案 And
在 Flutter我如何绘制边框半径选项卡指示器,如下图所示? 下面的代码只能绘制我在 github 中找到的圆形指示器. TabBar( isScrollable: true, contro
有没有办法获得相当于 _merge合并后的指标变量 dplyr ? 类似于 Pandas indicator = True选项基本上告诉你合并是如何进行的(每个数据集有多少匹配项等)。 这是 Pand
如何实现红色数字指示器(例如电子邮件计数通知)? 最佳答案 您正在寻找的是 applicationIconBadgeNumber 属性,它是 UIApplication 的属性。 要从应用中的任何位置
我目前正在为客户开发一个应用程序,他们提出了一个奇怪的请求。该请求涉及将自定义图像作为 ScrollView 的指示器。我什至不确定这是否可能,但如果可以,请让我知道如何做到这一点。 谢谢 最佳答案
有人知道 iPhone UISlider 控件有两个拇指的版本吗?我需要一个允许指定一系列值的控件。 UISlider API 文档暗示这对于标准控件来说是不可能的,所以我想知道是否有人对此有解决方案
我有一个 swing GUI 应用程序,其中包含一个框架类 MainFrame 和一个扩展 JPanel 的类 PanelPlan。我通过使用 BufferedReader 逐行读取文本文件并进行其他
我在 ember 路由中有一些模型。 model() { return this.get('store').query('orders', {}) } 我还有适配器,可以发送 ajax。 型号
我编写了一个程序来替换文件中的字符串。我在 C 中以 r+ 模式打开文件。现在一切正常,但是当程序替换字符串时,文件大小将减小,例如我有一个内容为 的文件 abcDEFgh 我想把DEF换成AA,就变
Currenlty 我在一个项目中工作,我必须从图库中选择多个图像,并且必须将所有选定的图像显示为可滑动 View (viewpager 指示器)。我已经看过很多示例,但在每个示例中我都找到了带有 v
我有一个数据类型为 JSON 的 AJAX 调用,当运行 AJAX 调用时,进度百分比显示在“console.log”中,但在完成上传文件之前达到百分比 100%在磁盘上。如何将百分比与流程的实际进度
我正在使用下面的代码。但当您旋转屏幕或重新运行应用程序时它会起作用。 pager.addOnPageChangeListener(new ViewPager.SimpleOnPageChangeLis
我是 android 的新手。我需要在同步时显示 Activity 指示器。单击按钮时,我将重定向到新 Activity 。在这个新 Activity 中,我正在同步。我需要在单击按钮时显示 Acti
是否可以添加 Activity 指示器作为警报的一部分?我需要这个,因为很难在白色背景中显示警报 View 。请提出想法。 最佳答案 我实际上是在搜索进度对话框...加载指示器 + 消息......
UIActivityIndicatorView *activityView = [[UIActivityIndicatorView alloc] initWithFrame:CGRectMake(0,
我是一名优秀的程序员,十分优秀!