AngularJS入门教程之模块化操作用法示例  更新时间:2016年11月02日 08:48:59   作者:Rongbo_J   这篇文章主要介绍了AngularJS模块化操作用法,结合实例形式分析了AngularJS基于模块化操作避免命名冲突的相关操作技巧,需要的朋友可以参考下 本文实例讲述了AngularJS模块化操作用法。分享给大家供大家参考,具体如下: 在前面几节教程中,代码比较少,为了方便说明问题笔者將控制器代码都写在了HTML页面中,实际上这并不是什么好的编程习惯,而且可维护性差。通常的做法都是將处理业务逻辑的代码写在一个单独的JS文件中,然后在HTML页面中引入该文件。 然而这样会带来新的问题,我们的控制器全都定义在全局的命名空间中,假设我们有一个公共的JS文件,在登录页面和密码修改页面都引入这个JS,A开发人员和B开发人员英雄所见略同,对控制器的命名都是UserController,这样就会导致命名冲突。而且我们在新增一个控制器的时候总是要担心是不是已经有了一个同名的控制器,代码的扩展性是不是很差呢? AngularJS中的模块能够很好的解决这个问题,接下来我们看看AngularJs怎么处理命名冲突问题。 代码清单1. tutorial04_1.html tutorial04_1 用户名: 密码: 提交 您输入的用户名:{{name}} 您输入的密码:{{pword}} 代码清单2. tutorial04_2.html tutorial04_2 密码: 提交 您输入的密码:{{pword}} 代码清单3. tutorial04.js var loginMod = angular.module(“loginMod”, []); loginMod.controller(“UserController”,function($scope,$log) { $scope.name=”admin”; $scope.pword=”123456″; $log.info( $scope.name); $log.info( $scope.pword); $scope.login = function() { alert(“登录”); } } ); var pwordMod = angular.module(“pwordMod”, []); pwordMod.controller(“UserController”,function($scope,$log) { $scope.pword=”123456″; $scope.changePwrd = function() { alert(“修改密码”); } } ); 我们有登录页面tutorial04_1.html和修改密码页面tutorial04_2.html,控制器代码都写在tutorial04.js中,在这两个页面中都定义了相同的控制器UserController。 var loginMod = angular.module(“loginMod”, []); 通过这行代码定义模块,第一个参数为模块名。第二个参数是一个数组,为可选,如果指定该参数则创建一个新的模块,不指定则从配置中检索。 loginMod.controller(“UserController”,function($scope,$log)… 通过controller函数向模块中添加一个控制器,第一个参数为控制器名称,第二个参数为控制器实现部分。 然后在tutorial04_1.html和tutorial04_2.html就可以使用ng-app=”loginMod”和ng-app=”pwordMod”来指定页面中的控制器属于哪个模块。 在浏览器中运行页面可以看到,不同页面调用不用模块中的UserController控制器: AngularJS源码可点击此处本站下载。 希望本文所述对大家AngularJS程序设计有所帮助。 您可能感兴趣的文章: 详解利用Angular实现多团队模块化SPA开发框架 angular.js + require.js构建模块化单页面应用的方法步骤 简单谈谈require模块化jquery和angular的问题 详解AngularJS 模块化 Angular的模块化(代码分享) AngularJS 模块化详解及实例代码 AngularJS 应用模块化的使用 AngularJS 模块化 相关文章 Angularjs中ng-repeat-start与ng-repeat-end的用法实例介绍 这篇文章主要给大家介绍了Angularjs中ng-repeat-start与ng-repeat-end的用法,文章开始先进行了简单的介绍,而后通过完整的实例代码详细给大家介绍这两者的用法,有需要的朋友们可以参考借鉴,下面来一起看看吧。 2016-12-12 Angular框架详解之视图抽象定义 这篇文章主要给大家介绍了关于Angular框架详解之视图抽象定义的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 2021-04-04 Angular管道PIPE的介绍与使用方法 这篇文章主要给大家介绍了关于Angular管道PIPE的相关资料,管道的作用就是传输,并且不同的管道具有不同的作用,需要的朋友可以参考下 2021-06-06 AngularJS中的Directive实现延迟加载 延迟加载通常是直到用户交互时才加载,那么如何实现延时加载的呢?下面通过本文一起学习AngularJS中的Directive实现延迟加载,对angularjs延时加载相关知识感兴趣的朋友一起学习吧 2016-01-01 Angular 实现输入框中显示文章标签的实例代码 这篇文章主要介绍了Angular 实现输入框中显示文章标签的实例代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下 2018-11-11 angular多语言配置详解 这篇文章主要介绍了angular多语言配置详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2019-05-05 使用AngularJS创建单页应用的编程指引 这篇文章主要介绍了使用AngularJS创建单页应用的编程指引,AngularJS是一款高人气的JavaScript库,需要的朋友可以参考下 2015-06-06 AngularJS 获取ng-repeat动态生成的ng-model值实例详解 这篇文章主要介绍了AngularJS 获取ng-repeat动态生成的ng-model值实例详解的相关资料,这里提供实例代码及实现效果图,需要的朋友可以参考下 2016-11-11 angularjs性能优化的方法 这篇文章主要介绍了angularjs性能优化的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2018-09-09 angular 实现的输入框数字千分位及保留几位小数点功能示例 这篇文章主要介绍了angular 实现的输入框数字千分位及保留几位小数点功能,涉及AngularJS数值运算、正则匹配等相关操作技巧,需要的朋友可以参考下 2018-06-06 最新评论

本文实例讲述了AngularJS模块化操作用法。分享给大家供大家参考,具体如下:

在前面几节教程中,代码比较少,为了方便说明问题笔者將控制器代码都写在了HTML页面中,实际上这并不是什么好的编程习惯,而且可维护性差。通常的做法都是將处理业务逻辑的代码写在一个单独的JS文件中,然后在HTML页面中引入该文件。

然而这样会带来新的问题,我们的控制器全都定义在全局的命名空间中,假设我们有一个公共的JS文件,在登录页面和密码修改页面都引入这个JS,A开发人员和B开发人员英雄所见略同,对控制器的命名都是UserController,这样就会导致命名冲突。而且我们在新增一个控制器的时候总是要担心是不是已经有了一个同名的控制器,代码的扩展性是不是很差呢?

AngularJS中的模块能够很好的解决这个问题,接下来我们看看AngularJs怎么处理命名冲突问题。

代码清单1. tutorial04_1.html

<!DOCTYPE html>
<html ng-app="loginMod">
<head lang="en">
 <meta charset="UTF-8">
 <script type="text/javascript" src="angular-1.3.0.14/angular.js"></script>
 <title>tutorial04_1</title>
</head>
<body>
<div ng-controller="UserController">
 用户名:<input type="text" ng-model="name" placeholder="用户名"/>
 密码:<input type="password" ng-model="pword" placeholder="密码"/>
 <button ng-click="login()">提交</button>
 <p>您输入的用户名:{{name}}</p>
 <p>您输入的密码:{{pword}}</p>
</div>
<script type="text/javascript" src="js/tutorial04.js">
</script>
</body>
</html>

代码清单2. tutorial04_2.html

<!DOCTYPE html>
<html ng-app="pwordMod">
<head lang="en">
 <meta charset="UTF-8">
 <script type="text/javascript" src="angular-1.3.0.14/angular.js"></script>
 <title>tutorial04_2</title>
</head>
<body>
<div ng-controller="UserController">
 密码:<input type="password" ng-model="pword" placeholder="密码"/>
 <button ng-click="changePwrd()">提交</button>
 <p>您输入的密码:{{pword}}</p>
</div>
<script type="text/javascript" src="js/tutorial04.js">
</script>
</body>
</html>

代码清单3. tutorial04.js

var loginMod = angular.module("loginMod", []);
loginMod.controller("UserController",function($scope,$log)
 {
  $scope.name="admin";
  $scope.pword="123456";
  $log.info( $scope.name);
  $log.info( $scope.pword);
  $scope.login = function()
  {
   alert("登录");
  }
 }
);
var pwordMod = angular.module("pwordMod", []);
pwordMod.controller("UserController",function($scope,$log)
 {
  $scope.pword="123456";
  $scope.changePwrd = function()
  {
   alert("修改密码");
  }
 }
);

我们有登录页面tutorial04_1.html和修改密码页面tutorial04_2.html,控制器代码都写在tutorial04.js中,在这两个页面中都定义了相同的控制器UserController。

var loginMod = angular.module("loginMod", []);

通过这行代码定义模块,第一个参数为模块名。第二个参数是一个数组,为可选,如果指定该参数则创建一个新的模块,不指定则从配置中检索。

loginMod.controller("UserController",function($scope,$log)...

通过controller函数向模块中添加一个控制器,第一个参数为控制器名称,第二个参数为控制器实现部分。

然后在tutorial04_1.html和tutorial04_2.html就可以使用ng-app=”loginMod”和ng-app=”pwordMod”来指定页面中的控制器属于哪个模块。

在浏览器中运行页面可以看到,不同页面调用不用模块中的UserController控制器:

AngularJS源码可点击此处本站下载

希望本文所述对大家AngularJS程序设计有所帮助。

您可能感兴趣的文章:

  • 详解利用Angular实现多团队模块化SPA开发框架
  • angular.js + require.js构建模块化单页面应用的方法步骤
  • 简单谈谈require模块化jquery和angular的问题
  • 详解AngularJS 模块化
  • Angular的模块化(代码分享)
  • AngularJS 模块化详解及实例代码
  • AngularJS 应用模块化的使用
张贴在3