如何在角度2中正确使用forEach循环?

时间:2018-01-23 04:23:43

标签: javascript angular foreach angular2-services

我是Angular2的新手,在这里我试图循环遍历数组“mmEditorTypes”并检查条件,如果满足条件,那么我将执行“open方法”。

但每当我执行以下代码时,我都会收到此错误:

portalModeService:加载portalMode抛出异常:

  

TypeError:无法读取未定义“。

的属性'forEach'

有人可以告诉我如何修复此错误吗?

porta.service.ts:

let mmApplicationType = this.applicationTypes['mm.application'];
    mmEditorTypes = [
      {
        type: mmApplicationType,
        payload: {
          'mm.application': 'mm.application'
        }
      }
    ];


mmEditorTypes.forEach(function(editor)  {
          if (!isAppContained(viewState, editor.type)) {
            this.applicationLifeCycleService.open(editor.type, editor.payload);
          }
});

function isAppContained(viewState, appType){
      let angular:any;
      let isContained = false;
      angular.forEach(viewState.appViewStates, function (appViewState) {
        if (appViewState.signature.appType === appType) {
          isContained = true;
        }
      });
      return isContained;
    }

2 个答案:

答案 0 :(得分:6)

正如@Sajeetharan所说,你不能在角度2 +中使用angular.forEach

所以你可以在打字稿中使用简单的foreach,如:

var someArray = [1, 2, 3];
someArray.forEach((item, index) => {
  console.log(item); // 1, 2, 3
  console.log(index); // 0, 1, 2
});

答案 1 :(得分:4)

您不能将 angular.forEach angular 一起使用,它与angularjs一起使用。

使用

for (let appViewState of viewState.appViewStates) {
   if (appViewState.signature.appType === appType) {
          isContained = true;
    }
}