[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的更多相关文章

  1. [AngularJS] 使用AngularAMD动态加载Controller

    [AngularJS] 使用AngularAMD动态加载Controller 前言 使用AngularJS来开发Single Page Application(SPA)的时候,可以选用AngularU ...

  2. [AngularJS] 使用AngularCSS动态加载CSS

    [AngularJS] 使用AngularCSS动态加载CSS 前言 使用AngularAMD动态加载Controller 使用AngularAMD动态加载Service 上列两篇文章里,介绍了如何如 ...

  3. AngularJS+RequireJs实现动态加载JS和页面的方案研究【上】

    1.入口页面 存放地址:src/main/webapp/WEB-INF/view/workflow/workflow.jsp [html] view plain copy 在CODE上查看代码片派生到 ...

  4. AngularJS+RequireJs实现动态加载JS和页面的方案研究【中】

    3.动态加载的内容: home.js [html] view plain copy 在CODE上查看代码片派生到我的代码片 define(['app'], function(app) { app.co ...

  5. angularJS配合bootstrap动态加载弹出提示内容

    1.bootstrp的弹出提示 bootstrap已经帮我们封装了非常好用的弹出提示Popover. http://v3.bootcss.com/javascript/#popovers 2.自定义p ...

  6. AngularJS+RequireJs实现动态加载JS和页面的方案研究【下】

    about.js: [html] view plain copy 在CODE上查看代码片派生到我的代码片 define(['app'], function(app) { app.controller( ...

  7. AngularJs 动态加载模块和依赖

    最近项目比较忙额,白天要上班,晚上回来还需要做Angular知识点的ppt给同事,毕竟年底要辞职了,项目的后续开发还是需要有人接手的,所以就占用了晚上学习的时间.本来一直不打算写这些第三方插件的学习笔 ...

  8. AngularJS + ui-router + RequireJS异步加载注册controller/directive/filter/service

    一般情况下我们会将项目所用到的controller/directive/filter/sercive预先加载完再初始化AngularJS模块,但是当项目比较复杂的情况下,应该是打开对应的界面才加载对应 ...

  9. 黄聪:AngularJS 动态加载控制器实例-ocLoazLazy

    一.AngularJS动态加载控制器和视图实例 路由配置关键代码: //二级页面 $stateProvider.state('main', { url: '/:name', /**如果需要动态加载数据 ...

随机推荐

  1. Linux (Ubuntu12.04) 下开发工具安装和使用

    Linux (Ubuntu12.04) 下开发工具安装和使用 这里讲述的是关于在ubuntu12.04下面安装和使用各种IDE 开发环境和初步使用的知识.说一下背景:很多的开发基本都是在linux操作 ...

  2. mongodb 关系、引用、覆盖索引查询

    一.关系 MongoDB 的关系表示多个文档之间在逻辑上的相互联系.文档间可以通过嵌入和引用来建立联系.MongoDB 中的关系可以是:1对1,1对多,多对1,多对多. 一个用户可以用多个地址,这是典 ...

  3. Tools - VirtualBox

    为CentOS虚拟机安装增强功能 启动CentOS虚拟机,点击"菜单 -> 设备 -> 安装增强功能". vboxadd的映像文件将会被挂载到虚拟机,在桌面也可以看到, ...

  4. Screenfly – 各种设备的屏幕和分辨率下快速测试网站

    Screenfly 让你能够在各种设备的屏幕和分辨率下查看你的网站.输入网址,并点击GO开始浏览网页.Screenfly 可以使用代理服务器来模拟设备,当您查看您的网站,代理服务器模仿您所选择的设备的 ...

  5. Mac删除JDK

    安装了1.6以后,没有安装1.7发现Android Studio报错: invalid source release: JDK 1.7 原因是Android Studio需要1.7以上的版本,结果再次 ...

  6. Eclipse快捷键(转)

    Ctrl+1 快速修复(最经典的快捷键,就不用多说了)Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加)Ctrl+Alt+↑ 复制当前行到上一行(复制增加)Alt+↓ 当 ...

  7. 基于HTML5的WebGL设计汉诺塔3D游戏

    在这里我们将构造一个基于HT for Web的HTML5+JavaScript来实现汉诺塔游戏. http://hightopo.com/demo/hanoi_20151106/index.html ...

  8. JS魔法堂:再识IE的内存泄露

    一.前言 IE6~8除了不遵守W3C标准和各种诡异外,我想最让人诟病的应该是内存泄露的问题了.这阵子趁项目技术调研的机会好好的再认识一回,以下内容若有纰漏请大家指正,谢谢! 目录一大坨! 二.内存泄漏 ...

  9. 音频文件解析(一):WAV格式文件头部解析

    WAV为微软公司(Microsoft)开发的一种声音文件格式,它符合RIFF(Resource Interchange File Format)文件规范,用于保存Windows平台的音频信息资源. 文 ...

  10. c# 中基类变量指向派生类对象的实例化

    这一篇文章转载自:http://www.xuebuyuan.com/390279.html 我对这篇文章进行了一一的验证,确实是这样子的,也明白了很多东西,觉得很有用,转载过来希望能够帮助大家. 1. ...