欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

AngularJS動(dòng)態(tài)加載模塊和依賴的方法分析

 更新時(shí)間:2016年11月08日 09:28:51   作者:前端超人  
這篇文章主要介紹了AngularJS動(dòng)態(tài)加載模塊和依賴的方法,結(jié)合實(shí)例形式分析了AngularJS使用ocLazyLoad實(shí)現(xiàn)動(dòng)態(tài)加載的相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了AngularJS動(dòng)態(tài)加載模塊和依賴的方法。分享給大家供大家參考,具體如下:

前言

由于AngularJS是單頁面應(yīng)用框架,在正常的情況下,會(huì)在訪問頁面的時(shí)候?qū)⑺械腃SS、JavaScript文件都加載進(jìn)來。文件不多的時(shí)候,頁面啟動(dòng)速度倒不會(huì)影響太多。但是一旦文件數(shù)太多或者加載的第三方庫比較大的時(shí)候,就會(huì)影響頁面啟動(dòng)速度。因此對(duì)于應(yīng)用規(guī)模大、文件數(shù)比較多或者加載的第三方庫比較大的時(shí)候,采用動(dòng)態(tài)加載JS或者動(dòng)態(tài)加載模塊會(huì)極大提升頁面的啟動(dòng)速度。本文將介紹如何利用ocLazyLoad實(shí)現(xiàn)動(dòng)態(tài)加載。

準(zhǔn)備

AngularJS動(dòng)態(tài)加載依賴第三方庫:ocLazyLoad。ocLazyLoad是一個(gè)第三方庫,支持AngularJS動(dòng)態(tài)加載module、service、directive以及靜態(tài)文件。

安裝ocLazyLoad

可通過npm或者bower進(jìn)行安裝

npm install oclazyload
bower install oclazyload

將ocLazyLoad module 添加到你的應(yīng)用中

angular.module('myApp',['oc.lazyLoad']);

配置 ocLazyLoad

你可以在 config函數(shù)中配置 $ocLazyLoadProvider,配置文件如下

.config(['$ocLazyLoadProvider', function($ocLazyLoadProvider){
  $ocLazyLoadProvider.config({
    debug: true,
    events: true,
    modules: [
      {
        name: 'TestModule',
        files: ['test.js']
      }
    ]
  })
}])

debug: 用來開啟debug模式。布爾值,默認(rèn)是false。當(dāng)開啟debug模式時(shí),$ocLazyLoad會(huì)打印出所有的錯(cuò)誤到console控制臺(tái)上。
events:當(dāng)你動(dòng)態(tài)加載了module的時(shí)候,$ocLazyLoad會(huì)廣播相應(yīng)的事件。布爾值,默認(rèn)為false。
modules:用于定義你需要?jiǎng)討B(tài)加載的模塊。定義每個(gè)模塊的名字需要唯一。
modules必須要用數(shù)組的形式,其中files也必須以數(shù)組的形式存在,哪怕只需要加載一個(gè)文件

在路由當(dāng)中加載module

.config(['$routeProvider', function($routeProvider) {
    $routeProvider.otherwise('/index');
    $routeProvider.when('/index', {
      templateUrl: 'index.html',
      controller: 'IndexController',
      resolve: { // resolve 里的屬性如果返回的是 promise對(duì)象,那么resolve將會(huì)在view加載之前執(zhí)行
        loadMyCtrl: ['$ocLazyLoad', function($ocLazyLoad) {
          // 在這里可以延遲加載任何文件或者剛才預(yù)定義的modules
          return $ocLazyLoad.load('TestModule'); //加載剛才定義的TestModule
          /*return $ocLazyLoad.load([  // 如果要加載多個(gè)module,需要寫成數(shù)組的形式
            'TestModule',
            'MainModule'
            ]);*/
        }]
      }
    })
}])

resolve設(shè)置的屬性可以被注入到Controller當(dāng)中。如果resolve返回的是promise對(duì)象的話,那么它們將在控制器加載以及$routeChangeSuccess被觸發(fā)之前執(zhí)行。

$ocLazyLoad就是利用這個(gè)原理hack,進(jìn)行動(dòng)態(tài)加載。

resolve的值可以是:

* key,the value of key 是會(huì)被注入到Controller的依賴的名字;
* factory,即可以是一個(gè)service的名字,也可以是一個(gè)返回值,它是會(huì)被注入到控制器中的函數(shù)或可以被resolve的promise對(duì)象。

通過這樣的配置,就可以實(shí)現(xiàn)了AngularJS動(dòng)態(tài)加載模塊和依賴。但是ocLazyLoad提供的功能更加豐富,不止動(dòng)態(tài)加載模塊和依賴,還能動(dòng)態(tài)加載service,diretive等。更多的功能,可以訪問[ocLazyLoad官網(wǎng)](https://oclazyload.readme.io)

希望本文所述對(duì)大家AngularJS程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Angular X中使用ngrx的方法詳解(附源碼)

    Angular X中使用ngrx的方法詳解(附源碼)

    ngrx是一套利用RxJS的類庫,下面這篇文章主要給大家介紹了關(guān)于Angular X中使用ngrx的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。
    2017-07-07
  • Angular4.x Event (DOM事件和自定義事件詳解)

    Angular4.x Event (DOM事件和自定義事件詳解)

    今天小編就為大家分享一篇Angular4.x Event (DOM事件和自定義事件詳解),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • Angular中樣式綁定解決方案

    Angular中樣式綁定解決方案

    這篇文章主要介紹了Angular中樣式綁定解決方案,使用ngClass和ngStyle可以進(jìn)行樣式的綁定,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08
  • angularjs 緩存的使用詳解

    angularjs 緩存的使用詳解

    這篇文章主要介紹了angularjs 緩存的使用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03
  • angular.js+node.js實(shí)現(xiàn)下載圖片處理詳解

    angular.js+node.js實(shí)現(xiàn)下載圖片處理詳解

    這篇文章主要介紹了angular.js+node.js實(shí)現(xiàn)下載圖片處理的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • angular4實(shí)現(xiàn)帶搜索的下拉框

    angular4實(shí)現(xiàn)帶搜索的下拉框

    這篇文章主要為大家詳細(xì)介紹了angular4實(shí)現(xiàn)帶搜索的下拉框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 詳解Angular中延遲加載的原理與使用

    詳解Angular中延遲加載的原理與使用

    Angular 是一個(gè)流行的框架,用于構(gòu)建動(dòng)態(tài)和響應(yīng)式 Web 應(yīng)用程序,在本文中,我們將討論延遲加載以及它如何與 Angular 中的路由一起工作,感興趣的可以跟隨小編一起學(xué)習(xí)一下
    2023-06-06
  • 如何用DevUI搭建自己的Angular組件庫

    如何用DevUI搭建自己的Angular組件庫

    DevUI 是一款面向企業(yè)中后臺(tái)產(chǎn)品的開源前端解決方案,它倡導(dǎo)沉浸、靈活、至簡的設(shè)計(jì)價(jià)值觀,提倡設(shè)計(jì)者為真實(shí)的需求服務(wù),為多數(shù)人的設(shè)計(jì),拒絕嘩眾取寵、取悅眼球的設(shè)計(jì)。如果你正在開發(fā) ToB 的工具類產(chǎn)品,DevUI 將是一個(gè)很不錯(cuò)的選擇!
    2021-05-05
  • AngularJs實(shí)現(xiàn)分頁功能不帶省略號(hào)的代碼

    AngularJs實(shí)現(xiàn)分頁功能不帶省略號(hào)的代碼

    這篇文章主要介紹了AngularJs實(shí)現(xiàn)分頁功能不帶省略號(hào)的代碼的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,感興趣的朋友一起看看吧
    2016-05-05
  • Angular中sweetalert彈框的基本使用教程

    Angular中sweetalert彈框的基本使用教程

    這篇文章主要給大家介紹了關(guān)于Angular中sweetalert彈框的基本使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07

最新評(píng)論