requirejs和AngularJS结合使用

最近一个项目要使用requirejs实现angularjs的js文件按需加载,在网上我也找了很多资料但是都不是很全,要么就不是很详细,所以我自己总结了一下,有需要的朋友可以看一下。废话不多说,直接上代码。

一、简单事例的项目目录如下:

  • index.html

js文件夹

--controller文件夹

  --- controllers.js

  --- controller1.js

  ---controller2.js

--directives文件夹

  ---directives.js

  ---directive1.js

--app.js

--router.js

--loader.js

--main.js

--angular-bootstrap.js

二、首页

首先你的index.html大概如下

   <!doctype html>
    <!-- <html xmlns:ng="//angularjs.org" id="ng-app" 
   ng-app="webApp"> -->
   <htmls>
   <head> 
   <meta charset="utf-8"> 
   <meta http-equiv="X-UA-Compatible" content="IE=edge, chrome=1">
  </head>
      <body>
    <!--其他html内容-->
       <script data-main="js/main" src="../lib/require/require.min.js"></script>
      </script>
    </body>
</html>

在首页index.html只需要引入requireJs库文件,并且指明入口函数main.js,采用手动启动angularjs应用,所以这里不用为首页添加ng-app='webApp'。

三、配置mian.js

  • 定义RequireJS配置
    require.config({
    urlArgs: "==version==",
    waitSeconds: 0,
    paths: {
    'jquery': '../../plugins/jQuery/jQuery-2.1.4.min',
    'bootstrap': '../../lib/bootstrap/dist/js/bootstrap.min',
    'angular': '../../lib/angular/angular.min',
    'angular-route': '../../lib/angular-route/angular-route.min',
    'angular-animate': '../../lib/angular-animate/angular-animate.min',
    'angular-resource': '../../lib/angular-resource/angular-resource.min',
    'angular-growl': '../../lib/angular-growl-v2/build/angular-growl.min',
    'domReady': '../../lib/require/domReady',
    'jquery-ui': '../../lib/jquery-ui/jquery-ui.min',
    },
    shim: {
    'angular': {
    exports: 'angular',
    deps: ['jquery']
    },
    'bootstrap': {
    deps: ['jquery']
    },
    'angular-route': {
    deps: ['angular']
    },
    'angular-animate': {
    deps: ['angular']
    },
    'angular-resource': {
    deps: ['angular']
    },
    'angular-growl': {
    deps: ['angular']
    },
    'slimscroll': {
    deps: ['jquery']
    },
    'tools': {
    deps: ['jquery']
    },
    'configs': {
    deps: ['jquery']
    },
    },
    deps: [
    'index-app',
    'tools',
    'configs',
    ]
    });

    require([
     'app',
     'routes',
             // 这是导入一个方法
     'loader',
     //注意:这不是Twitter Bootstrap,而是AngularJS bootstrap
     'angular-bootstrap',
     //所创建的所有控制器、服务、指令及过滤器文件都必须写到这里,这块内容必须手动维护
     'controllers/controllers',
     'directives/directives',
           ],
       function(app, config, loader) {
     'use strict';
     app.config([
         '$routeProvider',
         '$locationProvider',
         '$controllerProvider',
         '$compileProvider',
         '$filterProvider',
         '$provide',
         "$httpProvider",
         'growlProvider',
         function($routeProvider, $locationProvider, $controllerProvider, $compileProvider, $filterProvider, $provide, $httpProvider, growlProvider) {
             app.registerController = $controllerProvider.register;
             app.registerDirective = $compileProvider.directive;
             app.registerFilter = $filterProvider.register;
             app.registerFactory = $provide.factory;
             app.registerService = $provide.service;
             console.log("config.routes"+config.routes);
             if(config.routes != undefined) {
                 angular.forEach(config.routes, function(route, path) {
                     $routeProvider.when(path, {
                         templateUrl: route.templateUrl,
                         controller: route.controller,
                         resolve: loader(route.dependencies)
                     });
                 });
             }
    
             if(config.defaultRoutePath != undefined) {
                 $routeProvider.otherwise({
                     redirectTo: config.defaultRoutePath
                 });
             }
             growlProvider.globalTimeToLive({
                 success: 3000,
                 error: 5000,
                 warning: 5000,
                 info: 5000
             });
             $httpProvider.defaults.withCredentials = true;
             $httpProvider.defaults.useXDomain = true;
             delete $httpProvider.defaults.headers.common['X-Requested-With'];
         }
     ]);
     return app;
     }
     );
    

所以总体上说main.js这个文件做的事情就是:由requirejs异步载入所有文件;
function里面就是各种依赖方法。

四、手动启动angularjs应用

angular-bootstrap.js文件

    //当DOM结构加载完成后,bootstrap.js文件将会命令AngularJS启 动起来并继续执行
    define(['angular', 'domReady', 'app'], function(angular, domReady) {
    require(['domReady!'], function(document) {
        angular.bootstrap(document, ['app']);
       });
    });

这里依赖于app.js和router.js,我们看看这两个文件分别做什么

五、angular.module

这时先看看平时我们在写angularjs应用是这样写的

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

  app.controller("foo",function($scope){});
  app.directive(...)

所以app.js里是这样的

 define([
'angular',
'angular-route',
'angular-resource',
'angular-animate',
'angular-growl',
'angular-animate',
     。。。

 ], function(angular) {
'use strict';
return angular.module('app', [
    'controllers',
    'directives',
    'angular-growl',
    'ngAnimate',
    'ngRoute',
     。。。
   ]);
});

六、网站路由设置

我们这里使用ng-router。所以我们的router.js应该是这样的,主要是用来定义路由的,关于ng-router的配置请自行查看相关知识,这里就简单略过
router.js

   define([], function() {
return {
    defaultRoutePath: '/index',
    routes: {
        '/index': {
            templateUrl: 'tpls/index.html',
            controller: 'indexCtr',
            dependencies: ['js/controllers/index.js', 'js/directives/derective1.js']
            //这就是按需导入js文件
        },
    
    }
};
});

当然还需要有loader文件 里面有我们定义按需加载的方法;
loader.js

define([], function() {
  return function(dependencies) {
// 返回路由的 resolve 定义, 
var definition = {
  // resolver 是一个函数, 返回一个 promise 对象;
  resolver: ['$q', '$rootScope', function($q, $rootScope) {
    // 创建一个延迟执行的 promise 对象
    var defered = $q.defer();
    // 使用 requirejs 的 require 方法加载的脚本
    require(dependencies, function() {
      $rootScope.$apply(function() {
        // 加载完脚本之后, 完成 promise 对象;
        defered.resolve();
      });
    });
    //返回延迟执行的 promise 对象, route 会等待 promise 对象完成
    return defered.promise;
  }]
};
return definition;
  }
 });

七、控制器

首先 controllers.js里我们要这样写

 define(['angular'], function(angular) {
      'use strict';
          var controllers = angular.module('controllers', []);
   controllers.config([ '$controllerProvider', function($controllerProvider) {
        controllers.registerController = $controllerProvider.register;
}
  ]);
  controllers.initController = function(controllerName, options) {
        var attrs = [];
        var fun = null;
      if(jQuery.isArray(options)) {
                attrs = options.slice(0, options.length - 1)
                fun = options[options.length - 1]
         } else {
            fun = options;
        }
        controllers.registerController(controllerName, fun);
          if (attrs.length > 0)
            fun.$inject = attrs;
          }
    return controllers;
  });

主要用来加载各个控制器(所有的控制器都将在这个文件中被加载),除此之外再不用做其他,因为我们可以有很多个控制器文件,按照具体需要进行添加。

contreller1.js里要这样写 这就是我们具体的控制器

  define(['controllers/controllers'], function(controllers) {
      'use strict';
  controllers.initController('user_centerCtrl', ['$scope', '$location', '$routeParams', '$timeout', '$http',
    function($scope, $location, $routeParams, $timeout, $http) {
        

        }
    ]);
 });

八、指令

同理directives.js也类似。

define(['angular'], function(angular) {
'use strict';
var directives = angular.module('directives', []);
directives.config([
'$compileProvider',
function($compileProvider) {
  directives.registerDirective = $compileProvider.directive;
      }
]);
directives.initDirective = function(directiveName, options) {
var attrs = [];
var fun = null;
if(jQuery.isArray(options)) {
  attrs = options.slice(0, options.length - 1)
  fun = options[options.length - 1]
} else {
  fun = options;
}
directives.registerDirective(directiveName, fun);
if (attrs.length > 0)
  fun.$inject = attrs;
}
return directives;
});

directive1.js

define(['directives/directives'],
  function(directives) {
  'use strict';

directives.initDirective("oprationtable", function() {
    return {
        restrict: 'AE',
        templateUrl: "tpls/operationTable.html",
        transclude: true,
        scope: {
            tabdata: '=',
        },
        link: function(scope, elem, attrs) {
            //console.log(attrs.tabdata)
            //scope.tabdata = attrs.tabdata
            //console.log(scope.tabdata)
        },
        controller: function($scope, $element, $attrs) {

        },
     }
 });

});

好了 剩下的服务啊 过滤器啊 都可以这样写
这就是比较完整requirejs和AngularJS结合使用项目搭建 希望对大家有帮助!
有帮助给个赞谢谢!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容