0

コードが実行されているこのチュートリアルを実行し、それを自分のものにしようとしました。しかし残念ながら、それはうまくいきません。次のエラーが表示されます。

angular.min.js:84Error: [$injector:unpr] http://errors.angularjs.org/1.2.9/$injector/unpr?p0=%24templateRequestProvider%20%3C-%20%24templateRequest%20%3C-%20%24route%20%3C-%20ngViewDirective
at Error (native)
at http://portfolio2.gerbenboersma.com/lib/angular.min.js:6:449
at http://portfolio2.gerbenboersma.com/lib/angular.min.js:32:125
at Object.c [as get] (http://portfolio2.gerbenboersma.com/lib/angular.min.js:30:200)
at http://portfolio2.gerbenboersma.com/lib/angular.min.js:32:193
at c (http://portfolio2.gerbenboersma.com/lib/angular.min.js:30:200)
at Object.d [as invoke] (http://portfolio2.gerbenboersma.com/lib/angular.min.js:30:417)
at http://portfolio2.gerbenboersma.com/lib/angular.min.js:32:211
at c (http://portfolio2.gerbenboersma.com/lib/angular.min.js:30:200)
at Object.d [as invoke] (http://portfolio2.gerbenboersma.com/lib/angular.min.js:30:417)

このエラーが頻繁にここに投稿されていることは知っていますが、それらのほとんどは私のコードよりも複雑なコードを扱っているため、当てはまらないようです。

私がフォローしていたチュートリアルは、動作状態でここにアップロードされています: http://gerbenboersma.com/sites/AngularTests/

私自身のコードはそれにほとんど似ています。私の最後のバージョンでは、すべて同じ名前を使用していました。ここにあります:

<!doctype html>
<html lang="en" ng-app="myApp">
<head>
    <title>Gerben Boersma | Portfolio | 2016</title>
    <link rel="stylesheet" href="css/styles.css">
    <script src="lib/angular.min.js"></script>
    <script src="lib/angular-route.min.js"></script>
    <script src="js/works.json"></script>
    <script src="js/controllers.js"></script>
    <script src="js/app.js"></script>
</head>
<body>
<div class="outer-content">
    <div class="green-bar"></div>
    <div class="content" ng-view>
    </div>
</div>
</body>
</html>

そして controllers.js:

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

artistControllers.controller('ListController', ['$scope', '$http', function($scope, $http) {
  $http.get('js/works.json').success(function(data) {
    $scope.works = data;
    $scope.artistOrder = 'name';
  });
}]);

そして app.js:

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

myApp.config(['$routeProvider', function($routeProvider) {
  $routeProvider.
  when('/list', {
    templateUrl: 'partials/list.html',
    controller: 'ListController'
  }).
  otherwise({
    redirectTo: '/list'
  });
}]);

私はこれらの作品をあまりにも長い間見てきましたが、それほど多くはありません. しかし、私は問題を見つけることができません。AngularJS エラー リファレンスによると、名前の付け方に問題がある可能性がありますが、これらの最新バージョンでは、元のチュートリアルの例から名前を変更していません。これはかなりうまく機能しているようです。誰かがこれに光を当ててくれることを願っています。

4

1 に答える 1

1

angular 1.2.9 を新しい angular-route 1.5.8 と一緒に使用しています。これにより前述の問題が発生します。1.2.9 の代わりに angular 1.5.8 を使用してください。 p=preview、angular の 1.2.9 バージョンのコメントを外し、1.5.8 バージョンのコメントを試みてください。問題が再現されます。

<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.5.8/angular.js"></script>
<!-- <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.2.9/angular.min.js"></script> -->
于 2016-10-04T21:55:58.843 に答える