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