<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      Angularjs的工程化

      Angularjs的工程化

      AMD規(guī)范和CMD規(guī)范

      為什么需要模塊化管理工具

      在編寫項目時可能需要加載很多js文件,若b.js依賴a.js,且a.js比b.js大很多,那么瀏覽器會讓b.js等待a.js加載完畢后再去執(zhí)行b.js里的內(nèi)容;而即使d.js并不依賴a.js,b.js,c.js,也會等待這三個文件均加載完畢才執(zhí)行,為了讓瀏覽器能夠按需加載,提出了模塊化管理工具。

      <script type="text/javascript" src="js/a.js"></script>
      <script type="text/javascript" src="js/b.js"></script>
      <script type="text/javascript" src="js/c.js"></script>
      <script type="text/javascript" src="js/d.js"></script>
      

      AMD規(guī)范

      全稱為Asynchronous Module Defined,即異步模塊管理,它通過使用依賴注入等方法完整描述了模塊的定義、依賴關(guān)系、引用關(guān)系以及加載機制,AngularJS、RequireJS均是符合AMD規(guī)范的。

      define函數(shù)

      函數(shù)中有三個參數(shù),前兩個參數(shù)可以省略,第三個參數(shù)是模塊的具體實現(xiàn)本身。 當(dāng)define函數(shù)執(zhí)行時,它首先會異步調(diào)用第二個參數(shù)中列出的依賴模塊,當(dāng)所有的模塊被載入完成之后,如果第三個參數(shù)是一個回調(diào)函數(shù)則執(zhí)行,然后告訴系統(tǒng)模塊可用,也通知了依賴于自己的模塊自己已經(jīng)可用。

      define([module-name?], [array-of-dependencies?], [module-factory-or-object]);
      
      其中:
      module-name: 模塊標(biāo)識,可以省略。
      array-of-dependencies: 所依賴的模塊,可以省略。
      module-factory-or-object: 模塊的實現(xiàn),或者一個JavaScript對象。
      

      下面代碼定義了一個alpha模塊,并且依賴于內(nèi)置的require,exports模塊,以及外部的beta模塊。

      define("alpha", ["require", "exports", "beta"], function (require, exports, beta) {
          exports.verb = function() {
          return beta.verb();
          };
      });
      

      案例

      項目結(jié)構(gòu)

      案例
      │ test.html

      └─js
      │ main.js
      │ math.js
      │ pi.js

      └─lib
      require.js

      項目代碼
      test.html
      <!DOCTYPE html>
      <html>
      <head>
      	<title>RequireJS學(xué)習(xí)</title>
      </head>
      <body>
          <script data-main="js/main.js" src="js/lib/require.js"></script>
          <!-- main.js是主入口文件 -->
      </body>
      </html>
      
      main.js
      requirejs.config({
      	baseUrl: 'js',  //所有js程序的根目錄
      	paths: {
      		//別名
      		"math": "math"
      	}
      });
      
      requirejs(["math"],
      	function(math){
      alert(math.squre(8));
      alert(math.area(10));
      	});
      alert("hello");
      
      math.js
      define(["pi"], function(pi){
      	alert("我是math");
      	return {
      		"squre": function(number){
      			return number * number;
      		},
      		"area": function(r){
      			return pi.pi * r *r;
      		}
      	};
      });
      
      pi.js
      define({
      	"pi": 3.1415926
      })
      
      項目說明
      • 在html文件中引包時需要同時指定require.js文件和main.js文件;

      • main.js是主入口文件,只有主入口main.js能用requirejs,其他入口只能用define;

      • math.js用define定義模塊,模塊暴露的API用return返回;

      • main.js中如果有語句不需要依賴別人的語句,可以不寫在回調(diào)函數(shù)里面,而現(xiàn)在很少有機會不在回調(diào)函數(shù)中寫語句,即AMD和CMD越來越像。

      CMD規(guī)范

      全稱為Common Module Defined,即普通模塊管理,其執(zhí)行過程是懶式的。NodeJS、SeaJS、CommonJS、webpack均是符合CMD規(guī)范的。

      define函數(shù)

      define(function(require, exports, module) {  
            // 模塊定義在此  
      });
      

      AngularJS的工程化

      angular-async-loader

      angular-async-loader可以輕松解決ReuqireJS和AngularJS之間的粘合問題。angular-async-loader官網(wǎng)

      安裝前端依賴

      大體思路就是用RequireJS配置AngularJS項目,配置步驟如下。

      • 進入項目文件夾,在命令行窗口執(zhí)行下列指令,創(chuàng)建bower前端依賴文件。

        bower init
        
      • 創(chuàng)建.bowerrc文件并進行配置(先創(chuàng)建一個空文檔,再在命令行用rename重命名為.bowerrc),配置內(nèi)容如下,配置后,用bower下載的模塊會生成在assets文件夾下。

        {
        	"directory" : "assets"
        }
        
      • 安裝AngularJS。

        bower install angular --save
        
      • 安裝ui-router。

        bower install angular-ui-router --save
        
      • 安裝RequireJS。

        bower install requirejs --save
        
      • 安裝angular-async-loader。

        bower install angular-async-loader --save
        

      書寫三大文件

      三大文件為app-routes.js、app.js、bootstrap.js。

      在項目根目錄下分別創(chuàng)建ngApp文件夾、app-routes.js、app.js、bootstrap.js、index.html文件。

      bootstrap.js

      bootstrap.js是RequireJS的入口文件。

      require.config({
          baseUrl: '/',
          //別名
          paths: {
              'angular': 'assets/angular/angular.min',
              'angular-ui-router': 'assets/angular-ui-router/release/angular-ui-router.min',
              'angular-async-loader': 'assets/angular-async-loader/dist/angular-async-loader.min'
          },
          //聲明paths中元素暴露的接口和依賴
          shim: {
              'angular': {exports: 'angular'},  //暴露的是angular
              'angular-ui-router': {deps: ['angular']}  //依賴的是angular
          }
      });
      //核心入口
      require(['angular', './app-routes'], function (angular) {
          //當(dāng)整個文檔就緒之后
          angular.element(document).ready(function () {
              //angular.bootstrap是一個方法,表示啟動angular
              angular.bootstrap(document, ['myapp']);
              //通過類名添加ng-app指令,也可以通過attr來添加
              angular.element(document).find('html').addClass('ng-app');
          });
      });
      

      app.js

      app.js中創(chuàng)建了app對象。

      define(function (require, exports, module) {
          //這是一個CMD規(guī)范的模塊,模塊的作用是向外暴露app整體
          //AMD只能向外暴露json形式的API
      
          //引入依賴
          var angular = require('angular');
          var asyncLoader = require('angular-async-loader');
      
          require('angular-ui-router');
      
          //創(chuàng)建app對象,app對象依賴ui.router
          var app = angular.module('app', ['ui.router']);
      
          // initialze app module for angular-async-loader
          asyncLoader.configure(app);
          //向外暴露
          module.exports = app;
      });
      

      app-routes.js

      app-routes.js中定義了路由,這里采用了連續(xù)依賴,bootstrap.js依賴app-routes.js,app-routes.js依賴app.js。

      define(function (require) {
          //引入app對象
          var app = require('./app');
          //定義路由
          app.config(['$stateProvider', '$urlRouterProvider', function ($stateProvider, $urlRouterProvider) {
              $urlRouterProvider.otherwise('/home');
      
              $stateProvider
                  .state('home', {
                      url: '/home',
                      template: '<h1>我是首頁!</h1>'
                  });
          }]);
      });
      

      index.html

      index.html是唯一的單頁面,但不表示只存在一個html頁面,其他頁面可作為模板存在,在index.html文件中創(chuàng)建一個ui-view容器,然后用RequireJS語法引用入口文件bootstrap.js。

      <!DOCTYPE html>
      <html>
      <head>
          <meta charset="utf-8" />
      	<title>
      		測試系統(tǒng)
      	</title>
      </head>
      <body>
          <ui-view></ui-view>
          
          <script type="text/javascript" src="assets/requirejs/require.js" data-main="bootstrap.js"></script>
      </body>
      </html>
      

      ngApp

      ngApp里可根據(jù)場景創(chuàng)建相應(yīng)文件夾,存放編寫控制器、服務(wù)和指令等內(nèi)容的js文件。此處創(chuàng)建root文件夾和home文件夾。

      root
      RootCtrl.js
      define(function (require) {
          var app = require('app');
          require('./rootService');
          // dynamic load services here or add into dependencies of ui-router state config
          // require('../services/usersService');
      
          app.controller('RootCtrl', ['$scope', 'rootService', function ($scope, rootService) {
              this.a = rootService.m;
          }]);
      
      });
      
      rootService.js
      define(function (require) {
          var app = require('app');
      
          // dynamic load services here or add into dependencies of ui-router state config
          // require('../services/usersService');
      
          app.factory("rootService", function () {
              return {
                  m : 9
              }
          });
      
      });
      
      template.html
      <div>
        <header>
          <h1>我是root的template文件</h1>
          {{rootCtrl.a}}
          <nav>
            <a ui-sref="root.home" ui-sref-active="cur">首頁</a>
          </nav>
        </header>
        <ui-view> </ui-view>
        <footer>我是footer</footer>
      </div>
      

      home

      HomeCtrl.js
      define(function (require) {
          var app = require('app');
          require('jquery');  //var $ = require('jquery');為什么不用變量接收,因為jquery的原理就是給window對象添加屬性
          require('jquery-ui');
          app.controller('HomeCtrl', [function () {
              this.a = 100;
              $('.box').animate({ 'font-size': 100 }, 1000, function () {
                  $(this).css("color", "red");
                  $(this).draggable();
              });
          }]);
          
      });
      
      template.html
      <div>
        <h1>我是首頁。{{homeCtrl.a}}</h1>
        <div class="box">你好</div>
      </div>
      

      jquery的引用

      法一:

      最簡單的方法就是在index.html上引用,這樣可以在全局上使用$函數(shù),缺點是不管頁面是否使用jquery,總是先會加載完畢。

      <!DOCTYPE html>
      <html>
        <head>
          <meta charset="utf-8" />
          <title>測試系統(tǒng)</title>
          <link rel="stylesheet" href="css/root.css" />
        </head>
        <body>
          <ui-view></ui-view>
          <script
            type="text/javascript"
            src="/assets/jquery/dist/jquery.min.js"
          ></script>
          <script
            type="text/javascript"
            src="/assets/requirejs/require.js"
            data-main="bootstrap.js"
          ></script>
        </body>
      </html>
      

      法二:

      也可以在bootstrap.js上起一個別名,使用RequireJS加載jquery。

      require.config({
          baseUrl: '/',
          //別名
          paths: {
              'angular': 'assets/angular/angular.min',
              'angular-ui-router': 'assets/angular-ui-router/release/angular-ui-router.min',
              'angular-async-loader': 'assets/angular-async-loader/dist/angular-async-loader.min',
              'jquery': 'assets/jquery/dist/jquery.min'
          },
          //聲明paths中元素暴露的接口和依賴
          shim: {
              'angular': {exports: 'angular'},  //暴露的是angular
              'angular-ui-router': { deps: ['angular'] },  //依賴的是angular
              'jquery': {exports: 'jquery'}  //暴露的是jquery
          }
      });
      

      然后在需要使用jquery的控制器中寫入如下代碼。

      define(function (require) {
          var app = require('app');
          var jquery = require('jquery');
          app.controller('HomeCtrl', [function () {
              jquery('.box').animate({ 'font-size': 100 }, 1000);
          }]);
          
      });
      

      若要引入jquery的插件,需要bower下載jquery-ui,然后改變bootstrap.js

      require.config({
          baseUrl: '/',
          //別名
          paths: {
              'angular': 'assets/angular/angular.min',
              'angular-ui-router': 'assets/angular-ui-router/release/angular-ui-router.min',
              'angular-async-loader': 'assets/angular-async-loader/dist/angular-async-loader.min',
              'jquery': 'assets/jquery/dist/jquery.min',
              'jquery-ui': 'assets/jquery-ui/jquery-ui.min'
          },
          //聲明paths中元素暴露的接口和依賴
          shim: {
              'angular': {exports: 'angular'},  //暴露的是angular
              'angular-ui-router': { deps: ['angular'] },  //依賴的是angular
              'jquery': {exports: 'jquery'},  //暴露的是jquery
              'jquery-ui': { deps: ['jquery'] },  //依賴的是jquery
          }
      });
      

      在控制器中寫入如下代碼。

      define(function (require) {
          var app = require('app');
          var $ = require('jquery');
          require('jquery-ui');
          app.controller('HomeCtrl', [function () {
              this.a = 100;
              $('.box').animate({ 'font-size': 100 }, 1000, function () {
                  $(this).css("color", "red");
                  $(this).draggable();
              });
          }]);
          
      });
      

      項目結(jié)構(gòu)

      項目
      │ app-routes.js
      │ app.js
      │ bootstrap.js
      │ index.html

      ├─assets
      │ ├─angular
      │ ├─angular-async-loader
      │ ├─angular-ui-router
      │ ├─jquery
      │ ├─jquery-ui

      ├─css
      │ root.css

      └─ngApp
      ├─home
      │ HomeCtrl.js
      │ template.html

      └─root
      RootCtrl.js
      rootService.js
      template.html

      注:在項目中使用ctrl+p,可以定位到目標(biāo)文件。

      posted @ 2023-01-29 10:21  大雄的叮當(dāng)貓  閱讀(260)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 久久精品这里热有精品| 色欲天天婬色婬香综合网| 视频免费完整版在线播放| 国产精品久久精品| 大胆欧美熟妇xxbbwwbw高潮了| 67194熟妇人妻欧美日韩| 日韩一卡二卡三卡四卡五卡 | 久久精品国产亚洲av麻| 亚洲国产天堂久久综合226114| 国产欧美日韩免费看AⅤ视频| 沧州市| 亚洲国产精品无码久久电影| 亚洲中文一区二区av| 国产精品中文字幕观看| 午夜dv内射一区二区| 动漫精品中文无码卡通动漫| 北岛玲亚洲一区二区三区| 国产亚洲天堂另类综合| 日本精品极品视频在线| 清纯唯美人妻少妇第一页| 亚洲精品成人福利网站| 人与禽交av在线播放| 国产一区二区av天堂热| 国产伦一区二区三区视频| 久久精品国产99国产精品严洲| 欧美三级在线播放| 国产成人精品国内自产色| 337p粉嫩大胆噜噜噜| 99国产精品欧美一区二区三区| 国产成人午夜一区二区三区| 国产免费福利网站| 中文字幕在线国产精品| 久章草这里只有精品| 国产女同疯狂作爱系列 | 国产亚洲欧美日韩在线一区二区三| caoporn成人免费公开| 国产午夜伦伦午夜伦无码| 日本亚洲一区二区精品| 丰满大爆乳波霸奶| 啦啦啦视频在线日韩精品| 26uuu另类亚洲欧美日本|