Angular:立即从ngClick函数返回
Angular: immediately return from ngClick function
我的页面上有一个下拉菜单,它实际上只是一个无序的列表,每个菜单项看起来像:
<li ng-click='doCalc(5)'>Five</li>
现在,doCalc
调用的函数可能需要一段时间:
function doCalc(num) {
factorial(num);
}
这意味着当factorial
运行时,菜单将保持在屏幕上。我希望doCalc
立即返回,而不是等待factorial
完成运行。
我知道如何通过无延迟的setTimeout和承诺来实现这一点但是角度方式是什么?搜索"angular promise"会产生大量关于HTTP请求的结果,而我在这里只是做了一个简单的计算。
可以使用$q
服务或$timeout
服务创建promise。
function doCalc(num) {
return $q.when(factorial(num));
};
或者
function doCalc(num) {
return $timeout(function() {return factorial(num)}, 0);
};
有人偏爱其中一种吗?如果我在页面中也有很多异步请求,会被阻止吗?
$q
服务和$timeout
服务都使用$q
队列(以及低于该setTimeout
的队列)。请注意,浏览器队列和Angular $q
队列都在一个线程上运行。这意味着一旦factorial
函数启动,它就会运行到完成。如果您担心factorial
服务会导致其他异步操作出现问题,则需要通过多次调用$q.when
或$timeout
(两者最终都调用setTimeout
)来分解该函数。
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 如何在JavaScript中将字符串转换为函数引用
- 用嵌套函数和默认函数定义函数
- 使用 jQuery 的 .on 函数如何获取事件的原始元素
- 无法导出函数expressjs/requestjs中的变量
- 函数参数中的数据与指定变量之间的任何性能差异
- JQuery合并了keyup和focusout两个函数
- ES6构造函数返回基类的实例
- 监视函数从服务返回不起作用,但作用域函数起作用
- 我可以在json对象中添加一个函数吗
- AngularJS:我可以跳过函数参数回调吗
- 如何使jQuery插件函数可调用以供独立使用,而不在集合上操作
- JavaScript数组排序(函数)用于对表行进行排序,而不是排序
- jquery点击函数select&取消选择
- 拨打'父亲'函数形式a'儿童'ReactJS中的组件
- Angular:立即从ngClick函数返回
- 使用Angular的ngClick来调用分配给另一个控制器的函数
- AngularJS ngclick切换函数调用
- AngularJS中ngclick的触发函数