zoukankan      html  css  js  c++  java
  • AngularJS快速入门指南12:模块

      AngularJS模块定义了一个application。

      模块是一个application中不同部分的容器。

      application中的所有控制器都应该属于一个模块。


    带有一个控制器的模块

      下面这个application("myApp")包含一个控制器("myCtrl"):

    <!DOCTYPE html>
    <html>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
    <body>
    
    <div ng-app="myApp" ng-controller="myCtrl">
    {{ firstName + " " + lastName }}
    </div>
    
    <script>
    var app = angular.module("myApp", []);
    app.controller("myCtrl", function($scope) {
        $scope.firstName = "John";
        $scope.lastName = "Doe";
    });
    </script>
    
    </body>
    </html>

    运行


    在JS文件中定义模块和控制器

      在AngularJS applications中,我们通常会将模块和控制器定义到不同的JavaScript文件中。

      在下面这个例子中,"myApp.js"包含了一个application的模块定义,"myCtrl.js"包含了控制器的定义:

    <!DOCTYPE html>
    <html>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
    <body>
    
    <div ng-app="myApp" ng-controller="myCtrl">
    {{ firstName + " " + lastName }}
    </div>
    
    <script src="myApp.js"></script>
    <script src="myCtrl.js"></script>
    
    </body>
    </html>

    myApp.js代码:

    var app = angular.module("myApp", []);
    Note 这里的参数[]可以被用来指定模块的依赖项(即需要加载的其它模块)

    myCtrl.js代码:

    app.controller("myCtrl", function($scope) {
        $scope.firstName    = "John";
        $scope.lastName= "Doe";
    });

    Global Namespace中的函数污染

      在JavaScript中要尽量避免使用全局函数。因为全局函数容易被其它的JavaScript代码改写或销毁。

      AngularJS模块的定义减少了出现这种问题的风险,尽量将函数定义到AngularJS模块中。


    何时加载Library?

    Note 在我们所有的示例代码中,AngularJS library都是在HTML文档的head部分被加载的。

      建议将脚本的引用放到<body>元素的最后。但你还是会看到许多的AngularJS示例代码将library的引用放在文档的head部分,这仅仅只是为了在library被加载后对angular.module的访问进行编译。

      另一个解决方法是将AngularJS library的引用放到<body>元素的最后,你自己的AngularJS脚本代码之前:

    <!DOCTYPE html>
    <html>
    <body>
    
    <div ng-app="myApp" ng-controller="myCtrl">
    {{ firstName + " " + lastName }}
    </div>
    
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
    <script>
    var app = angular.module("myApp", []);
    app.controller("myCtrl", function($scope) {
        $scope.firstName = "John";
        $scope.lastName = "Doe";
    });
    </script>
    
    </body>
    </html>
  • 相关阅读:
    参与 Microsoft 开发者社区,发挥自己的技术价值。
    Silverlight 与HTML元素交互操作
    冯瑞涛的新浪技术微博正式上线!欢迎您的关注。
    Silverlight Object 标签属性介绍、初始化参数的设置和获取、客户端系统信息获取
    Visual Studio 2010 RC 公共下载开放,开发者可以通过下面的地址下载
    C# Socket 同步通信与异步通信 示例
    解决 Visual Studio 打开项目 “Project could not be opened because Microsoft Visual C# 2008 compiler could not be created” 报错
    Silverlight 与javaScript互操作
    Windows Mobile 6.5 设置 QQ 通过 WiFi 连接登录
    黑龙江.Net俱乐部在博客园安家了,欢迎您的加入、关注和参与我们的线下活动。
  • 原文地址:https://www.cnblogs.com/jaxu/p/4497005.html
Copyright © 2011-2022 走看看