首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AngularJS和异步操作

AngularJS和异步操作
EN

Stack Overflow用户
提问于 2014-08-29 18:16:58
回答 1查看 200关注 0票数 0

我正在用AngularJS构建一个非常基本的应用程序。我需要做的事情之一是从列表中删除项目。为了做到这一点,我编写了以下代码:

代码语言:javascript
复制
$scope.removeItem = function(item) {
  var toRemove = -1;
  angular.forEach($scope.items, function(_item, key) {
    if (item === _item) {
      toRemove = key;
      return false;
    }
  });       

  if (toRemove >= 0) {
    $scope.items.splice(i, 1);
    return true;
  }
  return false;
};

这似乎起作用了。然而,我的数据集相对较小。我搞不懂的是.forEach。该函数异步运行吗?换句话说,我在angular.forEach下面的代码能在.forEach完成之前执行吗?我一直听说异步操作。然而,我不明白这是什么时候发生的,什么时候不发生。

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-29 18:19:42

不,这不是异步的。angular.forEach不异步运行。在完成forEach之前,forEach下面的代码无法运行。这是肯定的。还有一件事是,您不必在return false迭代函数中执行forEach。在您的情况下,它是没有用的,它仍然将运行整个循环,即使您的第一个项目符合条件。

我认为您可能将forEach误解为异步操作,可能是因为您注册的函数。它只是一个迭代函数,您可以使用它来计算每个迭代。

异步函数的例子是$timeout (setTimeout)、$interval (setInterval)、允诺回调、ajax回调、animationFrames等等。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25573990

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档