【问题标题】:Why my If statement is not working 100 % in JS in AngularJS为什么我的 If 语句在 AngularJS 中的 JS 中不能 100% 工作
【发布时间】: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


【解决方案1】:

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

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 发帖。

【讨论】:

  • 如何避免这种情况?
  • 似乎 query() 从承诺返回数组。你能展示一下这个方法吗?如果你返回 Promise,你可以在这个 Promise 上使用 then,成功后用 rmaHasDefects 调用另一个 Promise 应该同步它。
  • 这是基本的 $resource 查询。你能用代码告诉我你的 returnin 承诺是什么意思吗?
  • 谢谢!我以前让它工作过。我只是将我的代码拆分为函数并使用 Promise 来确保所有内容都是从 db 中获取的。非常感谢您的帮助,正是您的评论对我帮助很大! JS 有时候太可怕了 :)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-01-14
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-11-25
  • 2021-11-24
相关资源
最近更新 更多