[AngularJS] 使用AngularAMD动态加载Service
[AngularJS] 使用AngularAMD动态加载Service
前言
「使用AngularAMD动态加载Controller」:这篇文章里介绍如何使用AngularAMD来动态加载Controller。本篇文章以此为基础,介绍如何使用AngularAMD来动态加载Service,让SPA的启动过程更加轻量化,用以提升使用者的操作体验。并且也透过这样挂载式的设计,让项目功能更加模块化,增加开发与维护的工作效率。主要为自己留个纪录,也希望能帮助到有需要的开发人员。
安装
本篇文章以「使用AngularAMD动态加载Controller」的范例程序为基础,为其附加动态加载Service的功能。进入本篇的开发步骤之前,开发人员可以先依照上一篇文章的步骤来建立基础架构。
动态加载Controller范例:点此下载
开发Service
取得基础架构之后,在工作文件夹内新增一个UserRepository.js档案,用来定义动态挂载的Service:UserRepository物件。
首先要在UserRepository.js里面加入下列require+AngularAMD语法,用来将UserRepository.js包装成为可以动态加载执行的AMD格式模块,并且注入AngularAMD所提供的app对象用来提供动态注册Servive的功能。(相关require.js的使用介绍,可以参考:require.js的用法 - 阮一峰的网络日志)
define(["app"], function (app) {
});
接着在UserRepository.js里,加入下列这个使用JavaScript面向对象语法写出来的UserRepository类别,后续会使用这个UserRepository类别来提供系统服务的功能。(相关JavaScript面向对象语法的介绍,建议参考:JavaScript 设计模式 - Stoyan Stefanov)
// class
var UserRepository = (function () {
// constructors
function UserRepository() {
// users
this.users = new Array();
this.users.push({ name: "Clark", address: "Taipei" });
this.users.push({ name: "Jeff", address: "Kaohsiung" });
this.users.push({ name: "Jammy", address: "Taipei" });
}
// methods
UserRepository.prototype.getUserByName = function (name) {
// result
var result = null;
for (var key in this.users) {
if (this.users[key].name == name) {
result = this.users[key];
}
}
// return
return result;
};
// return
return UserRepository;
})();
最后在UserRepository.js里面加入下列程序代码,使用AngularAMD所提供的app对象把UserRepository类别动态注册成为Angular的一个服务。这个动态把UserRepository类别动态注册成为Angular的服务的程序代码定义,会在UserRepository.js这个AMD格式档案被加载后执行。(相关AngularAMD所提供的动态注册功能,可以参考:AngularAMD:Creating a Module - marcoslin)
// register
app.service("UserRepository", [UserRepository]);
加载Service
完成Service的开发工作之后,接着就要在Controller里使用上个步骤所建立的UserRepository。首先编辑工作文件夹内既有的about.js,并且将其中require语法的宣告定义,修改为下列的程序内容。在这段程序中"UserRepository"字符串,代表的意义是使用require.js的功能,去动态加载UserRepository.js这个AMD格式档案。
about.js
define(["UserRepository"], function () {
//...
});
动态加载UserRepository.js之后,系统就会依照程序代码定义,将UserRepository类别注册成为Angular的一个服务。这时开发人员就可以修改about.js里面的Controller宣告,使用Angular语法取得UserRepository服务来提供Controller使用。
about.js
// controller
return ["$scope", "UserRepository", function ($scope, UserRepository) { // properties
$scope.title = "This is About page";
$scope.user = UserRepository.getUserByName("Clark");
}];
about.html
<h1>{{ title }}</h1>
<h1>{{ user | json }}</h1>
<br/>
<button ui-sref="home">Home</button>
执行
完成开发步骤后,就可以准备使用Chrome执行index.html来检视成果。但是在检视成果之前,必须要先参考下列数据开启Chrome的必要功能,后续就使用Chrome来正常的执行index.html。
执行index.html之后,会系统依照路由设定进入预设的Home页面。而使用Chrome的开发者工具,可以看到系统加载了Home页面的Template、Controller,并且显示在页面上。
点击Home页面的About按钮,会切换到About页面。这时同样从Chrome的开发者工具中,可以看到系统是在点击了About按钮之后,才去加载About页面的Template、Controller、以及额外的UserRepository来提供服务,这也就是AngularAMD所提供的动态加载Service功能。
范例下载
范例档案:点此下载
[AngularJS] 使用AngularAMD动态加载Service的更多相关文章
- [AngularJS] 使用AngularAMD动态加载Controller
[AngularJS] 使用AngularAMD动态加载Controller 前言 使用AngularJS来开发Single Page Application(SPA)的时候,可以选用AngularU ...
- [AngularJS] 使用AngularCSS动态加载CSS
[AngularJS] 使用AngularCSS动态加载CSS 前言 使用AngularAMD动态加载Controller 使用AngularAMD动态加载Service 上列两篇文章里,介绍了如何如 ...
- AngularJS+RequireJs实现动态加载JS和页面的方案研究【上】
1.入口页面 存放地址:src/main/webapp/WEB-INF/view/workflow/workflow.jsp [html] view plain copy 在CODE上查看代码片派生到 ...
- AngularJS+RequireJs实现动态加载JS和页面的方案研究【中】
3.动态加载的内容: home.js [html] view plain copy 在CODE上查看代码片派生到我的代码片 define(['app'], function(app) { app.co ...
- angularJS配合bootstrap动态加载弹出提示内容
1.bootstrp的弹出提示 bootstrap已经帮我们封装了非常好用的弹出提示Popover. http://v3.bootcss.com/javascript/#popovers 2.自定义p ...
- AngularJS+RequireJs实现动态加载JS和页面的方案研究【下】
about.js: [html] view plain copy 在CODE上查看代码片派生到我的代码片 define(['app'], function(app) { app.controller( ...
- AngularJs 动态加载模块和依赖
最近项目比较忙额,白天要上班,晚上回来还需要做Angular知识点的ppt给同事,毕竟年底要辞职了,项目的后续开发还是需要有人接手的,所以就占用了晚上学习的时间.本来一直不打算写这些第三方插件的学习笔 ...
- AngularJS + ui-router + RequireJS异步加载注册controller/directive/filter/service
一般情况下我们会将项目所用到的controller/directive/filter/sercive预先加载完再初始化AngularJS模块,但是当项目比较复杂的情况下,应该是打开对应的界面才加载对应 ...
- 黄聪:AngularJS 动态加载控制器实例-ocLoazLazy
一.AngularJS动态加载控制器和视图实例 路由配置关键代码: //二级页面 $stateProvider.state('main', { url: '/:name', /**如果需要动态加载数据 ...
随机推荐
- CCNA学习 NAT网络地址转换
CCNA基础 NAT网络地址转换 在计算机网络中,网络地址转换(Network Address Translation,缩写为NAT),也叫做网络掩蔽或者IP掩蔽(IP masquerading),是 ...
- mysql数据库移植
在mysql数据库移植的时候,把自己电脑上mysql中data目录的一些重要文件复制到其他电脑上,先备份一下其他电脑上的mysql的data目录,然后替换! 例如我的mysql默认的数据库文件位置: ...
- java接口中多继承的问题
java中支撑多继承吗? 支持->接口啊 为什么接口支持多继承呢?因为接口中没有方法体!即使可能两个接口中有一样的抽象方法,但是 只会调用子类中覆盖该同样抽象方法的具体方法!不会引起调用的歧义! ...
- office快速制作简历
毕业的一年是由学校向社会转变的一年,面临着人生的一个重大转折--找工作.在如今信息爆炸的时代,纵使力拔山兮气盖世也难免会被遗落芳草之中而不得一展宏图.对未来的憧憬,对美好生活的向往,或多或少你需要一份 ...
- jQuery中$.extend
$.fn是指jquery的命名空间,加上fn上的方法及属性,会对jquery实例每一个有效. 如扩展$.fn.abc(),即$.fn.abc()是对jquery扩展了一个abc方法,那么后面你的每一个 ...
- CSS 魔法系列:纯 CSS 绘制各种图形《系列五》
我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 CSS3 的广泛使用,更多新奇的 CSS 作品涌现出来. ...
- EasyUI笔记
以下功能实现朋友们若有更好的思路办法,欢迎留言交流. 1.关闭其他标签页(右键菜单触发,保留左侧第一个欢迎tab) 问题:取到的数组tabs长度会随着tab的关闭而变化 思路:先遍历需要关闭的标签页t ...
- Mina架构与优化指南
MINA架构 这里,我借用了一张Trustin Lee在Asia 2006的ppt里面的图片来介绍MINA的架构. Remote Peer就是客户端,而下方的框是MINA的主要结构,各个框之间的箭头代 ...
- [New Portal]Windows Azure Virtual Machine (15) 在本地制作数据文件VHD并上传至Azure(2)
<Windows Azure Platform 系列文章目录> 在上一章内容里,我们已经将包含有OFFICE2013 ISO安装文件的VHD上传至Azure Blob Storage中了. ...
- java设计模式学习(-)
在我目前看来博客的作用就是笔记了,所谓的原创也仅仅是复制了别人的东西实践了一下,但为了学习记忆确实要记录下来.在这里感谢网络各处的资源,原谅我对资源的索取. 接下来每天开始学以则设计模式或者几天学一则 ...