快速点击 Angularjs 应用页面时无法加载

When clicking very quickly on Angularjs app page doesn't load

仅供参考 - 我是 Angular 的新手...不是我的代码,主要来自我正在玩的 Lynda 教程。 我注意到,当我在执行 "pagination" 类型时显示 data.json 文件中的不同元素时,如果我点击后退锚点链接的速度太快而无法显示下一个或上一个,则页面不会加载物品。罪魁祸首开始于此处(details.html 文件)/细节控制器中的锚标记。我想知道是不是 async/await 没有被使用的问题。

<div class="container">
    <div class="row">
      <div class="col-12 mt-3">
          <div class="card">
            <div class="card-header d-flex align-items-start justify-content-between">
              <h1 class="card-title my-0">{{artists[whichItem].name}}</h1>
              <nav class="btn-group">
                <a class="btn btn-sm btn-secondary" 
                  href="#/details/{{prevItem}}">&lt;</a>
                <a class="btn btn-sm btn-secondary" 
                  href="#/">&bull;Home</a>
                <a class="btn btn-sm btn-secondary" 
                  href="#/details/{{nextItem}}">&gt;</a>
              </nav>
            </div>
            <div class="card-body"
              ng-model="artists">
              <h4 class="card-title text-dark mt-0">{{artists[whichItem].reknown}}</h4>
              <img class="float-left mr-2 rounded"
                ng-src="images/{{artists[whichItem].shortname}}_tn.jpg"
                alt="Photo of {{artists[whichItem].name}}">
              <div class="card-text text-secondary">{{artists[whichItem].bio}}</div>
            </div>
          </div>
      </div>
    </div>
  </div>

与此同时 - 通过在线搜索不同的东西,我添加了

.otherwise({
  redirectTo: '/'
});

重定向以便显示内容。如果有人可以帮助解释造成这种情况的原因以及解决方法,那就太好了。我在下面发布代码。我还添加了 console.logs 来帮助我在我的控制器中进行调试,但我没有成功。

我的小控制器 - (controllers.js):

var myControllers = angular.module('myControllers', []);

myControllers.controller('SearchController', function MyController($scope, $http) {
    $scope.sortArtistBy = 'name';
    $http.get('js/data.json').then(
      (response) => $scope.artists = response.data
    );
}); 

myControllers.controller('DetailsController', function MyController($scope, $http, $routeParams) {
  $http.get('js/data.json').then(
    function(response) {
      $scope.artists = response.data
      $scope.whichItem = $routeParams.itemId;

      if($routeParams.itemId > 0){
        $scope.prevItem = Number($routeParams.itemId) - 1;
        console.log("I am going to 18")
      } else {
        console.log("I am going to 20")
        $scope.prevItem = $scope.artists.length - 1;
      }

      if($routeParams.itemId < $scope.artists.length - 1){
        console.log("I am going to 25")
        $scope.nextItem = Number($routeParams.itemId) + 1;
      } else {
        console.log("I am going to 28")
        $scope.nextItem = 0;
      }
    }
  );
}); 

我的主应用控制器(app.js):

var myApp = angular.module('myApp', [
  'ngRoute',
  'myControllers'
]);

myApp.config(['$routeProvider', function($routeProvider) {
  $routeProvider
    .when('/', {
      templateUrl: 'js/partials/search.html',
      controller: 'SearchController'
    })
    .when('/details/:itemId', {
      templateUrl: 'js/partials/details.html',
      controller: 'DetailsController'
    })
    .otherwise({
      redirectTo: '/'
    });
}]);

我的(index.html)文件:

<!DOCTYPE html>
<html ng-app="myApp">
<head>
  <meta charset="utf-8">
  <title>AngularJS</title>
  <meta name="viewport" content="width=device-width">

  <link rel="stylesheet" href="lib/bootstrap/bootstrap.min.css">
  <link rel="stylesheet" href="css/style.css">

  <script src="lib/angular/angular.min.js"></script>
  <script src="lib/angular/angular-route.min.js"></script>

  <script src="js/app.js"></script>
  <script src="js/controllers.js"></script>
</head>
<body class="bg-secondary">

<div ng-view></div>


<script src="lib/jquery/jquery.min.js"></script>
<script src="lib/bootstrap/popper.min.js"></script>
<script src="lib/bootstrap/bootstrap.min.js"></script>

</body>
</html>

一种方法是在服务中缓存数据:

app.service("dataService", function($http) {
    var cache;
    this.get = () => {
        cache = cache || $http.get('js/data.json');
        return cache;
    };
})

然后在控制器中:

app.controller('DetailsController', function MyController($scope, dataService, $routeParams) {
  dataService().then(
    function(response) {
      $scope.artists = response.data
      $scope.whichItem = $routeParams.itemId;
      //...
    }
  );
});

通过缓存 $http promise,应用程序避免向服务器重复相同的请求。