AngularJS мерцает стол - PullRequest
       6

AngularJS мерцает стол

0 голосов
/ 01 ноября 2018

У меня есть простое приложение AngularJS, которое показывает таблицу с данными по ng-repeat после входа пользователя. У меня возникла проблема, когда после входа в систему таблица кратко показывает пустые строки, а затем фактические строки с данными. Любые предложения о том, как это исправить?

Это контроллер для входа в систему:

  $scope.login = function(user) {
    loginSrvc.login(user).then(function(response) {
      if (response == "authentication failed") {
        $scope.error = true;
        $scope.user = {};
         $location.path("/");
      } else {
        if (response.group_name == "On Site Registration"){
             var data = {
               event: response.zk_event_id,
               group: response.zk_group_id
             };
             $scope.getAvailableCamper(data);

        }
        else if (!response.zk_group_id) {
                   $location.path("/form/" + response.zkp_camper_id);
             }
             else {
             $location.path("/dashboard/" + response.zk_event_id + "/" + response.zk_group_id);
             }
      }

    })
  }


$scope.getAvailableCamper = function(data) {
    dashboardSrvc.fetchGroup(data).then(function(response){
         var findAvailableCamper = _.find(response.data, {status: null});
         console.log("this is find", findAvailableCamper);
         var id = findAvailableCamper.zkp_camper_id;
        $location.path("/onSiteForm/" + id);

    })
  }

Это контроллер для таблицы:

$scope.campers = function() {
    $scope.camper = loginSrvc.getCampers();
  }

  $scope.campers();

  $scope.fetchCampers = function(id) {
    dashboardSrvc.fetchCampers(id).then(function(response){
        $location.path("/form/" + id);
    })
  }

Вот HTML-код для таблицы:

<tr ng-repeat="campers in camper">
            <td>{{$index + 1}}</td>
            <td>{{campers.name_first}}</td>
            <td>{{campers.name_last}}</td>
            <td><button type="submit" name="submit" ng-click="register(campers)" class="btn btn-success" role="button" ng-hide="campers.status == 'Submitted' "  ng-disabled="!(!!campers.name_first && !!campers.name_last && !!campers.gender && !!campers.city && !!campers.date_of_birth && !!campers.email && !!campers.emergency_cell_phone && !!campers.emergency_contact_first_name && !!campers.emergency_contact_last_name && !!campers.emergency_home_phone && !!campers.relationship_to_camper && !!campers.first_time_flag )">Submit</button> <p ng-show ="campers.status == 'Submitted'" > {{campers.registration_date | date: 'medium'}}

            </p>
            </td>
            <td>{{campers.status}}</td>
            <td>
              <button ng-click="fetchCampers(campers.zkp_camper_id)"  type="submit" name="view" class="btn btn-default" role="button" ng-show="campers.status == 'Submitted' "><span class="glyphicon glyphicon-eye-open"></span></button>
              <button ng-click="fetchCampers(campers.zkp_camper_id)" type="submit" name="edit" class="btn btn-default" role="button" ng-hide="campers.status == 'Submitted' " ><span class="glyphicon glyphicon-edit"></span></button>

  <button type="button" ng-click="setValue(campers.zkp_camper_id)" name="deleteModalLauncher" id="deleteModalLauncher" class="btn btn-danger" role="button" data-toggle="modal" data-target="#deleteModal" ng-hide="campers.status == 'Submitted' " ><span class="glyphicon glyphicon-trash" aria-hidden="true"></span></button>

            </td>
          </tr>

Я очень ценю помощь! Спасибо!

1 Ответ

0 голосов
/ 01 ноября 2018

Существует директива, чтобы минимизировать мерцание, которое делает угловой цикл при проверке привязок и все. он называется ng-cloak и может быть добавлен к любому элементу на ваш взгляд.

Подробнее: https://www.w3schools.com/angular/ng_ng-cloak.asp

...

Вы также можете использовать событие angularjs, которое запускается, когда содержимое полностью загружено, и устанавливать флаг ex. загружен = истина, а затем используйте ng-show с загруженной переменной.

Контроллер:

$scope.$on('$viewContentLoaded', function(){
   $scope.loaded = true;
});

Просмотр:

<table ng-show="loaded">
  .....
 </table>

Надеюсь, это поможет!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...