gpt4 book ai didi

javascript - 为什么我的 If 语句在 AngularJS 中的 JS 中不能 100% 工作

转载 作者:行者123 更新时间:2023-12-03 09:32:34 24 4
gpt4 key购买 nike

enter image description here我有一个 $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}
});
}]);

最佳答案

defectDescsArray 是通过 Promise 来应用的。rmaHasDefects Promise 函数被调用,它也是一个 Promise。rmaHasDefects promise 然后保证,主体代码在成功调用后执行。但问题是,当执行的代码运行时,您无法保证 defectDescsArray 是一个包含值的数组,因为 Promise 调用不同步。这就是为什么,有时一个 Promise 先完成,这是正常情况,有时另一个 Promise 先完成,然后 reasonList 为空。为了证明这一点,请在 Promise 中记录 defectDescsArray,您会发现有时它是空的,有时不是。

for (var j = 0; j < defectDescsArray.length; j++) {
console.log('defectDescsArray length:',defectDescsArray.length);
if (result[i].rmaHasDefectdescPK.defectdescDefectdescId === defectDescsArray[j].defectdescId) {
<小时/>

解决方案是通过在资源上使用 Promise 来同步两个 Promise。

  defectDescsArray= defectDescSvc.query();
//using a promise and second call is inside a promise to determine not empty //array.
defectDescsArray.$promise.then(function (result) {
defectDescsArray = result;
$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);

});
});

我基于this邮政。

关于javascript - 为什么我的 If 语句在 AngularJS 中的 JS 中不能 100% 工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31454517/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com