1、定义index.html主页,对于通用的js就不用require依赖加载了,其中main.js作为主模块,用require添加系统路由模块。

 <!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Wms</title>
<link href="static/bootstrap-3.3.7-dist/css/bootstrap.css" rel="stylesheet"/>
<link href="static/Site.css" rel="stylesheet"/>
<script src="static/jquery-3.2.1.js"></script>
<script src="static/bootstrap-3.3.7-dist/js/bootstrap.js"></script>
<script src="node_modules/angular/angular.js"></script>
<script src="node_modules/angular-ui-router/release/angular-ui-router.js"></script>
<script src="static/require.js"></script>
<script src="main.js"></script>
</head>
<body>
<div class="navbar navbar-inverse navbar-fixed-top">
<div class="container">
<ui-view></ui-view>
</div>
</div>
</body>
</html>

2、main.js启动模块,加载所有路由模块,app配置路由后启动App。(以下只定义了master路由模块,实际业务可能分很多模块)

 require.config({
paths: {
'app': './app',
'masterRouter': './01-master/masterRouter'
}
}); require(['app', 'masterRouter'], function (app, masterRouter) {
app.config(masterRouter);
angular.bootstrap(document, ['App']);
console.log('系统已启动...');
});

3、app.js模块就是angular定义的主模块(只负责定义,设置provider代理供其他辅助模块使用),设置必要的拦截器,例如请求中添加token令牌、返回后调用Service的预处理等。

 define([], function () {
var app = angular.module('App', ['ui.router']); app.factory('interceptor', function ($q) {
return {
request: function (config) {
console.log(config.url);
if (config.url.indexOf('/login/') === -1) {
config.headers['token'] = '1234';
}
console.log(config.headers);
return config || $q.when(config);
},
response: function (response) {
if (response.config.url.indexOf('service') > -1) {
//todo 预处理请求结果
}
return response || $q.when(response);
}
};
}); app.config(function ($controllerProvider, $provide, $stateProvider, $urlRouterProvider, $httpProvider) {
// 在app上定义动态注册代理方法
app.ctrl = $controllerProvider.register;
app.service = $provide.service;
app.factory = $provide.factory;
app.state = $stateProvider.state; $httpProvider.interceptors.push('interceptor'); // 延迟加载方法
app.loadJs = function (files) {
return {
ctrl: function ($q) {
var wait = $q.defer();
require(files, function () {
wait.resolve();
});
return wait.promise;
}
};
}; // 定义主菜单、默认页
$stateProvider.state('main', {
url: '/main',
templateUrl: './00-menu/menu.html',
controller: 'menuCtrl',
resolve: app.loadJs(['./00-menu/menuCtrl.js'])
}).state('main.index', {
url: '/index',
templateUrl: './00-menu/index.html',
controller: 'indexCtrl',
resolve: app.loadJs(['./00-menu/indexCtrl.js'])
}); // 默认页
$urlRouterProvider.otherwise("main");
}); return app;
});

4、masterRouter.js 主要负责master模块的路由,必须要在App启动前加载进来。resolve:app.loadJs就是根据实际用到的控制器模块动态加载js,实际上项目上最多的并不是像echars等的通用模块,而是各种controller的业务模块,不能一次性加载进来,否则启动页太慢了,才resolve根据需要动态加载。

 define(['app'], function (app) {
return function ($stateProvider) {
var modulePath = './01-master/';
$stateProvider
.state('main.userMng', {
url: '/users',
templateUrl: modulePath + 'users.html',
controller: 'usersCtrl',
resolve: app.loadJs([modulePath + 'usersCtrl.js'])
})
.state('main.roleMng', {
url: '/roles',
templateUrl: modulePath + 'roles.html',
controller: 'rolesCtrl',
resolve: app.loadJs([modulePath + 'rolesCtrl.js'])
})
.state('main.authMng', {
url: '/auth',
templateUrl: modulePath + 'auth.html',
controller: 'authCtrl',
resolve: app.loadJs([modulePath + 'authCtrl.js'])
})
.state('main.setting', {
url: '/setting',
templateUrl: modulePath + 'setting.html',
controller: 'settingCtrl',
resolve: app.loadJs([modulePath + 'settingCtrl.js'])
})
.state('main.whsMng', {
url: '/whs',
templateUrl: modulePath + 'whs.html',
controller: 'whsCtrl',
resolve: app.loadJs([modulePath + 'whsCtrl.js'])
})
.state('main.matsMng', {
url: '/mats',
templateUrl: modulePath + 'mats.html',
controller: 'matsCtrl',
resolve: app.loadJs([modulePath + 'matsCtrl.js'])
})
.state('main.suppliersMng', {
url: '/suppliers',
templateUrl: modulePath + 'suppliers.html',
controller: 'suppliersCtrl',
resolve: app.loadJs([modulePath + 'suppliersCtrl.js'])
})
.state('main.customersMng', {
url: '/customers',
templateUrl: modulePath + 'customers.html',
controller: 'customersCtrl',
resolve: app.loadJs([modulePath + 'customersCtrl.js'])
});
};
});

5、usersCtrl.js 以用户users管理为例,的控制器模块的定义、和状态机state路由的定义。

 define(['app'], function (app) {

     app.ctrl('usersCtrl', function ($scope) {
$scope.title = 'users';
}); });
             .state('main.userMng', {
url: '/users',
templateUrl: modulePath + 'users.html',
controller: 'usersCtrl',
resolve: app.loadJs([modulePath + 'usersCtrl.js'])
})

6、以下是截图,首次启动加载的文件列表、及顺序。

2017.12.16 续 ==> 其实应该完全用require依赖,这样页面加载的顺序更加容易理解好看。

1、index.html页面简化。

 <!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Wms</title>
<link href="static/bootstrap-3.3.7-dist/css/bootstrap.css" rel="stylesheet"/>
<link href="static/Site.css" rel="stylesheet"/>
<script src="static/require.js" data-main="main"></script>
</head>
<body>
<div class="navbar navbar-inverse navbar-fixed-top">
<div class="container">
<ui-view></ui-view>
</div>
</div>
</body>
</html>

2、main.js添加依赖关系。

 require.config({
paths: {
'jquery': './static/jquery-3.2.1',
'bootstrap': './static/bootstrap-3.3.7-dist/js/bootstrap',
'angular': './node_modules/angular/angular',
'ui-router': 'node_modules/angular-ui-router/release/angular-ui-router',
'app': './app',
'masterRouter': './01-master/masterRouter'
},
shim: {
'bootstrap': {
deps: ['jquery'],
exports: 'bootstrap'
},
'ui-router': {
deps: ['angular'],
exports: 'ui-router'
},
'app': {
deps: ['ui-router'],
exports: 'app'
},
'masterRouter': {
deps: ['app'],
exports: 'masterRouter'
}
}
}); // 有返回值的写在前面,方便填写注入的参数
require(['app', 'masterRouter', 'jquery', 'bootstrap', 'angular', 'ui-router'], function (app, masterRouter) {
app.config(masterRouter);
angular.bootstrap(document, ['App']);
console.log('系统已启动...');
});

3、这次页面加载的顺序比较容易理解好看。

angular-ui-router动态加载模块的更多相关文章

  1. stevedore动态加载模块

    stevedore动态加载模块,stevedore使用setuptools的entry points来定义并加载插件.entry point引用的是定义在模块中的对象,比如类.函数.实例等,只要在im ...

  2. OrchardCore 如何动态加载模块?

    前言 今天,我们再次讨论下OrchardCore,通过初期调研,我们项目采用OrchardCore底层设施支持模块化,同时根据业务场景,额外还需支持二次开发,于是有了本文,若有不同解决方案,欢迎留言探 ...

  3. Python_getattr+__import__ 实现动态加载模块、类对象或函数

    __import__() 语法 __import__(name[, globals[, locals[, fromlist[, level]]]]) 参数 name -- 字符串,模块的导入路径 说明 ...

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

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

  5. React router动态加载组件-适配器模式的应用

    前言 本文讲述怎么实现动态加载组件,并借此阐述适配器模式. 一.普通路由例子 import Center from 'page/center'; import Data from 'page/data ...

  6. [driver]linux内核动态加载模块

    问题: 1. 把编译好的模块放到板子/lib/modules对应文件夹下,并且执行了depmod -a, 比如pl2303.ko, 那么下一次插入pl2303的串口线,是否可以识别,也就是自动加载pl ...

  7. nginx平滑升级、在线添加模块(tengine 动态加载模块)

    http://www.orzace.com/how-to-upgrade-nginx/ 下面是nginx替换成tengine再加上lua 模块,(tengine-2.0.1版本暂时无法动态加载lua模 ...

  8. Easy UI combogrid动态加载数据

    场景: datagrid的每一行允许编辑,一行中有一个字段,编辑时,提供下拉框选项,供选择. 下拉框选项有多个列.如下图所示:(点击红框内的下拉按钮,会弹出绿框内的内容) 要求: 每行弹出的下拉框内容 ...

  9. Apache动态加载模块

    添加步骤:如要额外安装cgi,先找到mod_cgi.c及mod_cgid.c.一般在apache安装包目录下,如 ./httpd-2.2.25/modules/generators .#编译安装 cg ...

随机推荐

  1. SQL Data Base 不装oracle客户端连接oracle服务端

    SQL Data Base  不装oracle客户端连接oracle服务端 一.直连: devart 二.拷贝dll: Oracle.DataAccess.dlloci.dllociw32.dll

  2. 安装npm及cnpm

    一.安装npm 1. 使用npm首先需要下载node.js 进入nodejs官网nodejs下载,如下图 : 选择适合自己的系统,我这里使用的是window10 64bit 2. 开始安装 **选好需 ...

  3. navicat 导入txt到数据库

    一直都是建库 一条条添加数据 昨天碰上要导入一堆数据突然不知所措 查资料才弄好,先记录一下,以免忘记 这个是导入的数据名可以改 对导入数据表进行增删改 以上!

  4. 标题title出现不规则背景

    Html代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...

  5. [转] 以普通用户启动的Vim如何保存需要root权限的文件

    [转] 以普通用户启动的Vim如何保存需要root权限的文件 在Linux上工作的朋友很可能遇到过这样一种情况,当你用Vim编辑完一个文件时,运行:wq保存退出,突然蹦出一个错误: E45: 'rea ...

  6. ResourceBundle和Locale

    一.认识国际化资源文件   这个类提供软件国际化的捷径.通过此类,可以使您所编写的程序可以:          轻松地本地化或翻译成不同的语言          一次处理多个语言环境          ...

  7. JavaScript高性能开发的十条建议

    JavaScript高性能开发的十条建议 文/开发部 Dimmacro 编者按:javascript开发大部分程序员都做过,写出来的代码质量也千差万别,现在浏览器内嵌的解释器虽然效率已经很高了,但在客 ...

  8. iOS开发之像素Compositing

    假如Layer S·在Layer D上面,则最终的屏幕的颜色值如下: \[R = S + D \cdot (1- S_\alpha)\] \(R\): 最终的RGB \(S\): source col ...

  9. BFC概念和作用,触发条件

    1.概念,全称是block format context,块级格式化上下文 2.触发条件 根元素 float属性不为none position为absolute或fixed display为inlin ...

  10. P5108 仰望半月的夜空

    题目链接 题意分析 给你一个字符串 让你求\(1-n\)长度下的字符串的中字典序最小并且最靠左的字符串的开头位置 我们考虑先建出\(SA\) 然后考虑对于一个字符串后缀排序之后 baba 后缀排序之后 ...