一、AngularJS动态加载控制器和视图实例

路由配置关键代码:

  1. //二级页面
  2. $stateProvider.state('main', {
  3. url: '/:name',
  4. /**如果需要动态加载数据和控制器***/
  5. views: {
  6. "": {
  7. templateUrl: function ($stateParams) {
  8. console.info($stateParams);
  9. return '/template/' + $stateParams.name + '.html';
  10. },
  11. resolve: {
  12. des: function ($ocLazyLoad, $stateParams) {
  13. if ($stateParams.name == 'about')
  14. return;
  15. return $ocLazyLoad.load('/scripts/myjs/' + $stateParams.name + '.js');
  16. }
  17. }
  18. }
  19. }
  20. });

1.引用:

  1. <script src="../Scripts/jquery-1.10.2.min.js"></script>
  2. <script src="../Scripts/Angular/angular.min.js"></script>
  3. <script src="../Scripts/Angular/ocLazyLoad.min.js"></script>
  4. <script src="../Scripts/Angular/angular-ui-router.min.js"></script>
  5. <link href="../Content/bootstrap.min.css" rel="stylesheet" />

2.HTML

  1. <div class="container" ng-app="myApp">
  2. <ul class="nav nav-pills">
  3. <li role="presentation"><a href="#/home">首页</a></li>
  4. <li role="presentation"><a href="#/about">关于页面</a></li>
  5. </ul>
  6. <div class="panel panel-danger">
  7. <div class="panel-heading">
  8. <div class="panel-title">模板内容</div>
  9. </div>
  10. <div class="panel-body" ui-view></div>
  11. </div>
  12. </div>

3.Js

    1. var app = angular.module('myApp', ['oc.lazyLoad', 'ui.router']);
    2. //配置路由
    3. app.config(function ($stateProvider, $urlRouterProvider) {
    4. $urlRouterProvider
    5. .when('', '/');
    6. //首页
    7. $stateProvider.state('index', {
    8. url: '/',
    9. templateProvider: function ($stateParams) {
    10. console.info('这是首页');
    11. return '<h1>这是首页</h1>';
    12. }
    13. });
    14. //二级页面
    15. $stateProvider.state('main', {
    16. url: '/:name',
    17. /***如果只是动态加载视图**/
    18. //templateUrl: function ($stateParams) {
    19. //    console.info($stateParams);
    20. //    return '/template/' + $stateParams.name + '.html';
    21. //},
    22. //controller: 'homeController',
    23. /**如果需要动态加载数据和控制器***/
    24. views: {
    25. "": {
    26. templateUrl: function ($stateParams) {
    27. console.info($stateParams);
    28. return '/template/' + $stateParams.name + '.html';
    29. },
    30. resolve: {
    31. des: function ($ocLazyLoad, $stateParams) {
    32. if ($stateParams.name == 'about')
    33. return;
    34. return $ocLazyLoad.load('/scripts/myjs/' + $stateParams.name + '.js');
    35. }
    36. }
    37. }
    38. }
    39. });
    40. });

http://blog.csdn.net/u011127019/article/details/53607852

黄聪:AngularJS 动态加载控制器实例-ocLoazLazy的更多相关文章

  1. 从零开始实现ASP.NET Core MVC的插件式开发(一) - 使用ApplicationPart动态加载控制器和视图

    标题:从零开始实现ASP.NET Core MVC的插件式开发(一) - 使用Application Part动态加载控制器和视图 作者:Lamond Lu 地址:http://www.cnblogs ...

  2. Swift微博项目--Swift中通过类名字符串创建类以及动态加载控制器的实现

    Swift中用类名字符串创建类(用到了命名空间) OC中可以直接通过类名的字符串转换成对应的类来操作,但是Swift中必须用到命名空间,也就是说Swift中通过字符串获取类的方式为NSClassFro ...

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

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

  4. angularjs 动态加载指令------编译服务$compile

    场景: 我们写了一个自定义的指令,这条指令需要一些数据,而这些数据需要在某些操作之后才能就绪,这时候,我们就需要在数据就绪之后,动态加载指令. 示例: js: $scope.$watch('repor ...

  5. angularjs 动态加载事件的另一种实现

    /** 初始化酒店列表 */ function inintHotel(params,url,$http,$scope){ $http.jsonp(url).success(function(res, ...

  6. 黄聪:异步加载JS的4种方式(详解)

    方案1:$(document).ready <!DOCTYPE html> <html> <head> <script src="http://co ...

  7. swift项目第四天:动态加载控制器

    一:Appdelegate import UIKit @UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate ...

  8. AngularCSS--关于angularjs动态加载css文件的方法(仅供参考)

    AngularCSS CSS on-demand for AngularJS Optimize the presentation layer of your single-page apps by d ...

  9. canvas制作圆形动态加载进度实例

    window.onload=function(){ var loading=document.getElementById('loading'); var context=loading.getCon ...

随机推荐

  1. Linux批量解压文件

    最近下载了Imagenet2012的数据文件,训练数据下有很多tar文件,这些tar文件都在一个目录内,所以想批量解压到该目录下每个单独的文件夹内 批量解压的步骤是, 1.列出所有的以tar为后缀的文 ...

  2. UV纹理+修改器:VertexWeightEdit+修改器:Mask遮罩

    UV纹理+修改器: VertexWeightEdit+修改器: Mask遮罩 基本流程, 如下图,准备地图一份, 黑白色即可. 纹理使用颜色绘制权重. 白色为1, 黑色为0. 新增球体, 细分多次, ...

  3. 铁三测试题——权限、你是管理员吗?——WP

    权限 [题目描述]:你是管理员吗? [解题链接]:http://ctf4.shiyanbar.com/web/root/index.php 首先看题,提到“权限”,“管理员”,这就是说涉及到管理员的账 ...

  4. 模块化,AMD规范

    模块化:代码量比较大,可能会有几个人同时写一个页面,同样写在一个文件里面,可能会有冲突,模块化可以解决代码的冲突(匿名函数调用,自己调用自己,就是立即执行函数) 团队的分工更加的明确 异步的执行: A ...

  5. BootStrap------之模态框1

    <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="utf-8& ...

  6. Go Example--闭包

    package main import "fmt" func main() { //这里需要将闭包函数当作一个类理解,这里是实例化 nextInt := intSeq() fmt. ...

  7. 生产环境部署MongoDB副本集(带keyfile安全认证以及用户权限)

    本文同步于个人Github博客:https://github.com/johnnian/Blog/issues/8,欢迎留言. 安装软件包:mongodb-linux-x86_64-3.4.1.tgz ...

  8. 被卡住的2个问题:1.输入url不执行后台的java方法 2.改了jsp页面,再次请求还是以前的那个页面

    1.问题 一个子项目,它的java代码都是打包到磁盘这个文件夹  D://commlib java代码改了之后,也是打包到这个文件夹里,刷新就可看见改了的. 要想子项目能运行,必须在主项目中从/com ...

  9. Singer 学习三 使用Singer进行mongodb 2 postgres 数据转换

    Singer 可以方便的进行数据的etl 处理,我们可以处理的数据可以是api 接口,也可以是数据库数据,或者 是文件 备注: 测试使用docker-compose 运行&&提供数据库 ...

  10. MySQL中正则表达式

    正则表达式是用来匹配文本的特殊的串(字符集合),将一个模式(正则表达式)与一个文本串进行比较 从文本文件中提取电话号码 查找名字中间带有数字的文件 文本块中重复出现的单词 替换页面的URL为这些URL ...