如何以角度导入模块并在视图上显示?

时间:2015-01-14 10:14:53

标签: javascript angularjs angularjs-directive angularjs-scope angular-ui

enter image description here

我正在尝试以角度加载我的第一个视图。但我以模块化方式制作了一个项目,以学习良好的编码风格。

我将展示如何创建一个目录来创建模块

或者在这里查看完整图片......

enter image description here

我在 index.html 页面

上写了这个
<!DOCTYPE html>
<html>
<head>
    <link rel="stylesheet" href="css/foundation.css" />
    <script src="lib/angular.js" type="text/javascript"></script>
    <script src="lib/angular-ui-router.js" type="text/javascript"></script>
    <script src="js/app.js" type="text/javascript"></script>
</head>

<body >
     <div ng-app="firstApp">
         <div ui-view="app"></div>
     </div>


</body>

</html>
app.js

中的

var app= angular.module('firstApp',['ui.router']);

在控制器 firstcontroller.js 文件中我写这个

(function() {
    'use strict';

    angular
        .module('firstApp')
        .controller('firstcont', firstcont);

    firstcont.$inject = ['$scope'];
    function firstcont($scope) {
        $scope.clickEvent=function(){
            alert('---')
        }
    }

})();

router.js 文件中我写这个

(function() {
    'use strict';

    angular.module('firstApp.firstdir').config(Routes);


    Routes.$inject = ['$stateProvider', '$urlRouterProvider'];
    function Routes($stateProvider, $urlRouterProvider) {
        // Default
        $urlRouterProvider.otherwise('/app');
        // Application
        $stateProvider
            .state('app', {
                url: '/app',
                views:{
                    app: { templateUrl: 'firstdir/templates/firstpage.html' }
                },
                controller:"firstcont"

            });
    }

})();
module.js 文件中的

我写这个

(function() {
    'use strict',

        angular.module('firstApp.firstdir', [
            'ui.router',
        ]);

})();

在template.html上我写了这个

<div ng-controller="firstcont">
    <h1>First page</h1>
    <button ng-click="clickEvent()"> go to second page</button>
</div>

我不知道它为什么不显示第一个视图。实际上,我无法制作plunker,因为没有办法制作目录?

angular.js:78 Uncaught Error: [$injector:modulerr] Failed to instantiate module firstApp due to:
Error: [$injector:modulerr] Failed to instantiate module firstApp.firstdir due to:
Error: [$injector:nomod] Module 'firstApp.firstdir' is not available! You either misspelled the module name or forgot to load it. If registering a module ensure that you specify the dependencies as the second argument.
http://errors.angularjs.org/1.2.21/$injector/nomod?p0=firstApp.firstdir
    at file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:78:12
    at file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:1668:17
    at ensure (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:1592:38)
    at module (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:1666:14)
    at file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3852:22
    at forEach (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:325:18)
    at loadModules (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3846:5)
    at file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3853:40
    at forEach (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:325:18)
    at loadModules (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3846:5)
http://errors.angularjs.org/1.2.21/$injector/modulerr?p0=firstApp.firstdir&…%3A%2FUsers%2Fnksharma%2FDesktop%2FAngularjs%2Flib%2Fangular.js%3A3846%3A5)
    at file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:78:12
    at file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3880:15
    at forEach (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:325:18)
    at loadModules (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3846:5)
    at file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3853:40
    at forEach (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:325:18)
    at loadModules (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3846:5)
    at createInjector (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:3786:11)
    at doBootstrap (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:1435:20)
    at bootstrap (file:///C:/Users/nksharma/Desktop/Angularjs/lib/angular.js:1450:12)
http://errors.angularjs.org/1.2.21/$injector/modulerr?p0=firstApp&p1=Error%…3A%2FUsers%2Fnksharma%2FDesktop%2FAngularjs%2Flib%2Fangular.js%3A1450%3A12)

2 个答案:

答案 0 :(得分:1)

首先包括js文件(模块声明始终排在第一位,第一个子模块)

<!-- The order here is very important -->
<script src="js/module.js" type="text/javascript"></script>
<script src="js/router.js" type="text/javascript"></script>
<script src="js/firstcontroller.js" type="text/javascript"></script>
<script src="js/app.js" type="text/javascript"></script>

将'firstcont'声明为firstApp.firstDir控制器:

var firstDir = angular.module('firstApp.firstdir');
...
firstDir.controller('firstcont', firstcont);

将您的子模块作为firstApp模块的依赖项:

//Remember firstApp.firstdir must be already declared :)
var app= angular.module('firstApp',['firstApp.firstdir', 'ui.router']);

更新: 这是代码示例http://goo.gl/xxvIvB(在预览中运行点击)

答案 1 :(得分:0)

您已在另一个模块中定义了您的路线:firstApp.firstdir。 要导入模块,请使用以下语法:

var app= angular.module('firstApp',['firstApp.firstdir']);

您不需要导入ui.router,因为它是从firstApp.firstdir导入的。