suchen

Heim  >  Fragen und Antworten  >  Hauptteil

前端 - ng-view不能加载进模板

在学习angularjs教程,ng-view 没有加载进模板,
但是按照官方的写法又能加载进模板,我自己的写法不行!
我的写法与官方的有啥区别,为啥不能加载进模板呢?
下面是我的项目目录结构

我的写法

app.js

'use strict';

/* App Module */
angular.module('phonecatApp',['ngRoute'])
.config(['$routeProvider',function($routeProvider) {
  $routeProvider
  .when('/phones',{
    templateUrl:'partials/phone-list.html',controller:'PhoneListCtrl'})
  .when('/phones/:phoneId', {
    templateUrl:'partials/phone-detail.html',controller:'PhoneDetailCtrl'})
  .otherwise({redirectTo: '/phones'});
}]);

controller.js

angular.module('phonecatApp',[])
.controller('PhoneListCtrl',['$scope','$http', function($scope, $http) {
    $http.get('phones/phones.json')
    .success(function(data) {
        $scope.phones = data.splice(0,5);
    });

    $scope.orderProp = 'age';

}])
.controller('PhoneDetailCtrl',['$scope','$routeParams',function($scope,$routeParams) {
    $scope.phoneId = $routeParams.phoneId;
}]);

官方教程上的写法

app.js

var phonecatApp = angular.module('phonecatApp', [
  'ngRoute',
  'phonecatControllers'
]);

phonecatApp.config(['$routeProvider',
 function($routeProvider) {
    $routeProvider.
      when('/phones', {
        templateUrl: 'partials/phone-list.html',
        controller: 'PhoneListCtrl'
      }).
      when('/phones/:phoneId', {
        templateUrl: 'partials/phone-detail.html',
        controller: 'PhoneDetailCtrl'
      }).
      otherwise({
        redirectTo: '/phones'
      });
  }]);

controller.js

var phonecatControllers = angular.module('phonecatControllers', []);
phonecatControllers.controller('PhoneListCtrl', ['$scope', '$http',
  function($scope, $http) {
    $http.get('phones/phones.json').success(function(data) {
      $scope.phones = data;
    });
   $scope.orderProp = 'age';
 }]);
phonecatControllers.controller('PhoneDetailCtrl', ['$scope', '$routeParams',
  function($scope, $routeParams) {
    $scope.phoneId = $routeParams.phoneId;
 }]);
PHP中文网PHP中文网2811 Tage vor599

Antworte allen(2)Ich werde antworten

  • 高洛峰

    高洛峰2017-05-15 16:59:16

    angular.module('phonecatApp',[])使用已存在的模块的时候不要加后面的依赖了。。。
    angular.module('phonecatApp')。。。这样就ok了!
    你上面那样类似重新定义了一个名为phonecatApp的模块,依赖是空[]。

    Antwort
    0
  • 天蓬老师

    天蓬老师2017-05-15 16:59:16

    module 重定义了,controller 里换个名字,app 中依赖它

    Antwort
    0
  • StornierenAntwort