【发布时间】:2015-10-05 22:00:45
【问题描述】:
我有一个$scope.reasonList,我用ng-repeat 进行迭代。但是,如果我用相同的数据返回和转发完全相同的页面,有时if 操作员不起作用并且$scope.reasonList 是空的。完全相同的数据和相同的页面?这些是我一直在比较的字符串。这里发生了什么以及为什么?
var reasons = new Array();
var roots = new Array();
var repairs = new Array();
var defectDescsArray = new Array();
defectDescsArray= defectDescSvc.query();
$scope.rma = rmaService.get({id: $routeParams.rmaId});
var rmaHasDefects = rmaDefectSvc.findByRmaId({rmaid: $routeParams.rmaId});
rmaHasDefects.$promise.then(function (result) {
alert('result.length:' +result.length)
for (var i = 0; i < result.length; i++) {
for (var j = 0; j < defectDescsArray.length; j++) {
if (result[i].rmaHasDefectdescPK.defectdescDefectdescId === defectDescsArray[j].defectdescId) {
$scope.showReasonList = true;
reasons.push(defectDescsArray[j]);
}
}
}
$scope.reasonList = reasons;
//$scope.$apply();
alert('$scope.reasonList.length' +$scope.reasonList.length);
});
查看
<div class="col-sm-10">
<table class="table table-striped table-condensed table-hover">
<tbody>
<tr ng-repeat="defect in reasonList">
<td>{{ defect.returnreasonReturnreasonId.returnText}}</td>
<td>{{ defect.text}}</td>
</TR>
</TBODY>
</table>
</div>
用于获取缺陷的 Angular 服务
angular.module('defectDescService', ['ngResource'])
.factory('defectDescSvc', ['$resource',
function ($resource) {
console.log('------defectDescService-----');
return $resource(
'/RMAServerMav/webresources/com.rako.entity.defectdesc/:id',
{},
{
delete: { method: 'DELETE', params: {id: '@defectdescId'}},
update: { method: 'PUT', params: {id: '@defectdescId'} },
findByDefectdescId:{
url: '/RMAServerMav/webresources/com.rako.entity.defectdesc/defect/:defid',
method: 'GET',
params: {defid: '@defid'},
isArray:true}
});
}]);
【问题讨论】:
-
视图是什么样的?
-
能否在 query() 函数后记录defectDescsArray?
-
@cyan 我编辑了我的问题。是的,我可以。这是一个静态列表,其中包含超过 100 个元素。
-
你如何使用路由?是您使用同一个控制器返回的页面吗?
-
@cyan 没有。这两个页面有自己的控制器。 Listcontroller 和修复控制器。
标签: javascript angularjs if-statement compare