此代码在开发人员控制台中导致错误:
$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
包含数据,它是一个对象;它非常复杂,所以我不会用它来混淆这个问题,但她是一张概述图片
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)
谁能看到我做错了什么?
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}]