AngularJS无法读取未定义的属性'forEach'

问题描述 投票:0回答:1

此代码在开发人员控制台中导致错误:

$scope.AddCandidatesToCompannies = function()
{
    console.table($scope.candidates);
    Object.entries($scope.candidates).forEach(candidate =>
    {
        candidate.jobs.forEach(job =>
        {
            var company_id = job['company_id'];

            Object.entries($scope.companies).forEach(company =>
            {
                if (company['company_id'] == company_id)
                {
                    console.log('match'); 
                };
            });
        });
    });
};   // AddCandidatesToCompannies()

$scope.candidates包含数据,它是一个对象;它非常复杂,所以我不会用它来混淆这个问题,但她是一张概述图片

enter image description here

Object.entries($scope.candidates).forEach(candidate =>发表声明

angular.min.js:83 TypeError:无法读取未定义的属性'forEach' 在mapController.js:138 在Array.forEach() at a。$ scope.AddCandidatesToCompannies(mapController.js:136) 在$ scope.ProcessSearchResults(mapController.js:161) 在C(angular.min.js:91) 在C(angular.min.js:91) 在angular.min.js:92 at h。$ eval(angular.min.js:100) at h。$ digest(angular.min.js:98) at h。$ apply(angular.min.js:101) 在f(angular.min.js:66) 在K(angular.min.js:70) 在XMLHttpRequest.y.onreadystatechange(angular.min.js:71)

谁能看到我做错了什么?

javascript angularjs google-chrome debugging syntax-error
1个回答
1
投票

Object.entries返回数组中的数组,然后是键值对。看起来你想拥有像Object.values($scope.candidates)这样的功能

例:

Object.entries($scope.candidates) == [[45,{candidate_id:45}],[46,{candidate_id:46}]]
Object.values($scope.candidates) == [{candidate_id:45}, {candidate_id: 46}]
© www.soinside.com 2019 - 2024. All rights reserved.