MEAN STACK AngularJS Просмотр страницы загружается до ответа Angular Service Response

У меня есть следующий вид контроллера.

'use strict';

angular.module('servers').controller

('PlcsrvnonprodsController', ['$scope',
'$stateParams', '$location', 'Authentication', 

'Plcsrvnonprods',
'Verticals','Datacenters','Functns','Technologys','Re

gions','$filter',
    function($scope, $stateParams, $location, 

Authentication, Plcsrvnonprods,


Verticals,Datacenters,Functns,Technologys,Regions,

$filter) {
          $scope.authentication = 

Authentication;
        $scope.currentPage = 1;
        $scope.pageSize = 10;
        $scope.offset = 0;
            $scope.loading = false;
            console.log('Now i am not 

dispalying the view'+$scope.loading);
            $scope.verticals = 

Verticals.query();
            $scope.datacenters = 

Datacenters.query();
            $scope.regions = 

Regions.query();
            $scope.functns = 

Functns.query();
            $scope.technologys = 

Technologys.query();
        // Page changed handler
        $scope.pageChanged = function() {
        $scope.offset = ($scope.currentPage - 

1) * $scope.pageSize;
        };


            var appendVars = function 

appendVars(p) {
                p.functn = $filter

('filter')($scope.functns, {_id: p.functn})[0];
                p.region = $filter

('filter')($scope.regions, {_id: p.region})[0];
                p.technology = 

$filter('filter')($scope.technologys, {_id: 

p.technology})[0];
                p.datacenter = 

$filter('filter')($scope.datacenters, {_id: 

p.datacenter})[0];
                p.vertical = $filter

('filter')($scope.verticals, {_id: p.vertical})[0];
            };


      //Find a list of serversrc
      $scope.find = function() {
         Plcsrvnonprods.query(function 

loadedPlcsrvnonprods(plcsrvnonprods){


plcsrvnonprods.forEach(appendVars);


$scope.plcsrvnonprods = plcsrvnonprods;
                 });
      }

            //Find requested server

            $scope.findOne = function() {
                $scope.plcsrvnonprod 

= Plcsrvnonprods.get({


plcsrvnonprodId: $stateParams.plcsrvnonprodId
                }, appendVars
               );
                 $scope.loading=true;
                console.log('All 

backend-calls succeeded, now displaying the view'+

$scope.loading);
            }


            // Update existing Product
            $scope.update = function() {
                var plcsrvnonprod = 

$scope.plcsrvnonprod;


plcsrvnonprod.vertical = plcsrvnonprod.vertical._id;


plcsrvnonprod.datacenter = 

plcsrvnonprod.datacenter._id;
                plcsrvnonprod.region 

= plcsrvnonprod.region._id;
                plcsrvnonprod.functn 

= plcsrvnonprod.functn._id;


plcsrvnonprod.technology = 

plcsrvnonprod.technology._id;
                plcsrvnonprod.

$update(function() {


$location.path('plcsrvnonprods/' + 

plcsrvnonprod._id);
                }, function

(errorResponse) {
                    $scope.error 

= errorResponse.data.message;
                });
            };

            // Remove existing Product
            $scope.remove = function

(plcsrvnonprod) {
                if ( plcsrvnonprod ) 

{


plcsrvnonprod.$remove();

                    for (var i in 

$scope.plcsrvnonprods) {
                        if 

($scope.plcsrvnonprods [i] === plcsrvnonprod) {


$scope.plcsrvnonprods.splice(i, 1);
                        }
                    }
                } else {


$scope.plcsrvnonprod.$remove(function() {


$location.path('plcsrvnonprods');
                    });
                }
            };

            //Search for the item.
            $scope.plcsrvnonprodSearch = 

function(product) {
                $location.path

('plcsrvnonprods/' + product._id);
            }
    }
]);

И у меня есть следующая страница просмотра:-

<section data-ng-controller="PlcsrvnonprodsController" data-ng-init="findOne()">
    <div class="page-header">
    <h1 data-ng-bind="plcsrvnonprod.dbname"></h1>
        <style>
        .ng-cloak {
            display: none !important;
        }
        </style>
    <div class="well col-md-12" ng-if="loading" class="ng-cloak">
            <div class="row">
      <div class="col-md-2">
        <Strong>Vertical</Strong>: <p>{{plcsrvnonprod.vertical.name}}</p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>Region</Strong>: <p>{{plcsrvnonprod.region.name}}</p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>DataCenter</Strong>: <p>{{plcsrvnonprod.datacenter.name}}</p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>DbTechnology</Strong>: <p>{{plcsrvnonprod.technology.name}}</p>
      </div>
      <div class="col-md-1"></div>
    </div>
        <div class="row">
            <div class="col-md-2">
        <Strong>Biz Function</Strong>: <p>{{plcsrvnonprod.functn.name}}</p>
      </div>
            <div class="col-md-1"></div>
            <div class="col-md-2">
        <Strong>DbMode</Strong>: <p data-ng-bind="plcsrvnonprod.environment"></p>
      </div>
      <div class="col-md-1"></div>
            <div class="col-md-2">
        <Strong>DbClustering</Strong>: <p data-ng-bind="plcsrvnonprod.clustered"></p>
      </div>
      <div class="col-md-1"></div>
        </div>
      <div class="row">
      <div class="col-md-2">
        <Strong>Hostname</Strong>: <p data-ng-bind="plcsrvnonprod.hostname"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>Dbname</Strong>: <p data-ng-bind="plcsrvnonprod.dbname"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>OS</Strong>: <p data-ng-bind="plcsrvnonprod.operating_system"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>DbVersion</Strong>: <p data-ng-bind="plcsrvnonprod.db_version"></p>
      </div>
      <div class="col-md-1"></div>
    </div>
    <div class="row">
      <div class="col-md-2">
        <Strong>MonitoringTool</Strong>: <p data-ng-bind="plcsrvnonprod.monitoring_tool"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>DbBkpStrategy</Strong>: <p data-ng-bind="plcsrvnonprod.backup_configuration"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>DbPriority</Strong>: <p data-ng-bind="plcsrvnonprod.criticality"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>DrSetup</Strong>: <p data-ng-bind="plcsrvnonprod.dr"></p>
      </div>
      <div class="col-md-1"></div>
    </div>
    <div class="row">
      <div class="col-md-2">
        <Strong>WalletUsage</Strong>: <p data-ng-bind="plcsrvnonprod.walletused"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>ApplName</Strong>: <p data-ng-bind="plcsrvnonprod.app_name"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>AppSpoc</Strong>: <p data-ng-bind="plcsrvnonprod.app_spoc"></p>
      </div>
      <div class="col-md-1"></div>
      <div class="col-md-2">
        <Strong>AppDl</Strong>: <p data-ng-bind="plcsrvnonprod.app_mailer"></p>
      </div>
      <div class="col-md-1"></div>
    </div>
        <hr/>
    <div class="row">
      <div class="col-md-12">
        <Strong>Special Instructions</Strong>: <p data-ng-bind="plcsrvnonprod.spl_instructions"></p>
      </div>
    </div>
        <hr/>
    </div>
  </div>
  <div class="pull-right">
        <a class="btn btn-primary" href="/#!/plcsrvnonprods">
            <i class="glyphicon glyphicon-backward"></i>
        </a>
    <a class="btn btn-primary" href="/#!/plcsrvnonprods/{{plcsrvnonprod._id}}/edit">
      <i class="glyphicon glyphicon-edit"></i>
    </a>
    <a class="btn btn-primary" data-ng-click="remove();">
      <i class="glyphicon glyphicon-trash"></i>
    </a>
  </div>
</section>

Ниже показано, как отвечает сервер: DESPITE с помощью ng-show или ng-cloak

GET /regions 304 120.419 ms - -
GET /verticals 304 137.192 ms - -
GET /plcsrvnonprods/5a874124a1346df954dff435 304 120.148 ms - -
GET /technologys 304 124.048 ms - -
GET /functns 304 130.483 ms - -
GET /datacenters 304 154.593 ms - 

GET-запросы как AngularService Calls, "technologys", "functns" и "datacenters" выполняются позже, чем GET для фактического представления. эти значения показаны как NULL.

Как я могу получить это поведение?

GET /verticals 304 75.307 ms - -
GET /datacenters 304 134.414 ms - -
GET /regions 304 179.821 ms - -
GET /functns 304 165.429 ms - -
GET /technologys 304 188.973 ms - -
GET /plcsrvnonprods/5a873d2076cfd0153a315e87 304 169.278 ms - -

И когда это происходит, мой взгляд загружает все значения правильно, и это происходит по случайности, и я не понимаю, почему это произошло именно так.

С уважением, Сай

1 ответ

Наконец, после нескольких дней борьбы я нашел эту работу, которая работает хорошо.

Так как я новичок в веб-разработке, и пока еще не совсем понимаю, я говорю, что это всего лишь обходной путь.

В моем представлении я вызываю $scope.findOne(), поскольку GET выполняется быстрее, чем вызовы AngularService, я решил снова вызвать этот метод "findOne()", так что мое представление будет перезагружено после 500 мс.

К этому времени все вызовы AngularService были бы завершены.

Поэтому я ввел $timeout в мой угловой контроллер и сделал следующее:

//Find requested server

            $scope.findOne = function() {
                $scope.plcsrvnonprod = Plcsrvnonprods.get({
                    plcsrvnonprodId: $stateParams.plcsrvnonprodId
                }, appendVars
               );
                 $timeout( function(){ $scope.findOneAgain(); }, 500);
            }

            $scope.findOneAgain = function() {
                $scope.plcsrvnonprod = Plcsrvnonprods.get({
                    plcsrvnonprodId: $stateParams.plcsrvnonprodId
                }, appendVars
                 );
            }

Теперь мой взгляд загружается успешно без каких-либо проблем.

Я надеюсь решить эту проблему навсегда, разумеется, после того, как у меня появятся навыки в Angular и JavaScript.

В ходе моего расследования я обнаружил, что использование $promises поможет с асинхронными вызовами, но я не совсем уверен, как их использовать и реализовать, так как я не знаю полностью JavaScript/AngularJS.

Надеюсь, этот обходной путь поможет новичку в стеке MEAN.

Эксперты:- Пожалуйста, не стесняйтесь комментировать постоянное решение. Между тем, я буду развивать свои навыки и доберусь до этого.

С уважением, Сай

Другие вопросы по тегам