Angularjs未遇到的错误:[$注射器:Modulerr] - 这里的菜鸟



我不使用nGroute或需要注入的任何角度服务。我认为我要注入自己的模块和控制器。但仍在控制台中遇到以下错误:

Uncaught Error: [$injector:modulerr] http://errors.angularjs.org/1.5.7/$injector/modulerr?p0=try&p1=Error%3A%20%…2015%2520experiments%2Fangulartrial%2Fjs%2Flib%2Fangular.min.js%3A21%3A163)
at angular.min.js:6
at angular.min.js:40
at r (angular.min.js:7)
at g (angular.min.js:39)
at db (angular.min.js:43)
at c (angular.min.js:20)
at Bc (angular.min.js:21)
at ge (angular.min.js:19)
at angular.min.js:315
at HTMLDocument.b (angular.min.js:189)

代码:index.html:

<html ng-app="try" lang="En">
<head>
    <title>Learn Angular 1.5</title>
    <!-- <script src="./js/lib/jquery-3.1.0.min.js" charset="utf-8"></script> -->
    <script src='./js/lib/angular.min.js'></script>
    <script src='app.js'></script>
    <script src='./js/app/blog-list.module.js'></script>
    <script src='./js/app/blog-list.component.js'></script>
</head>
<body>
    <div class='' ng-controller = 'BlogListController'>
    </div>
</body>
</html>

app.js:

angular.module ('try', ['blogList'])
    //This works when I declare the controller right here
    // .controller('BlogListController', function(){
    //  console.log("Hello");
    // })

blog-list.module.js

'use strict';
//simply declare the module here 
angular.module('blogList', [
    //inject dependencies
    'BlogListController'
    ]);

blog-list.component.js

 //declare the controllers, components etc on the module here 
angular.module('blogList')
    .controller('BlogListController', function(){
        console.log("Hello");
    });

问题在这里 BlogListController作为depdendency,

angular.module('blogList', [
    //inject dependencies
    'BlogListController'
    ]);

将其更改为

angular.module('blogList', []);

从依赖项中删除BloglistController

这是因为您没有使用'Bloglist'模块。将其更改为:

<html ng-app="blogList" lang="En">
 ...
</html>

在声明模块时,您也不会注入" BloglistController"。该数组是用于依赖于您新创建的模块运行的外部模块的依赖注入

(ex:ngroute是一个流行的模块,不会"脱离框",必须通过依赖注入包括)

相关内容

最新更新