老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

RequireJs怎么用-創新互聯

這篇文章將為大家詳細講解有關RequireJs怎么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創新互聯成立于2013年,先為嘉陵等服務建站,嘉陵等地企業,進行企業商務咨詢服務。為嘉陵企業網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。

一、為什么使用RequireJS?

 
  
  

上述多個js文件加載的時候,瀏覽器會停止網頁渲染(JS阻塞瀏覽器渲染),加載文件越多,網頁失去響應的時間就會越長;另外各文件的依賴關系很難管理。

RequireJs的作用:

(1)實現js文件的異步加載,避免網頁失去響應;

(2)管理模塊之間的依賴性,便于代碼的編寫和維護。

(3)定義了一個作用域來避免全局名稱空間污染。

二、require.js的加載

1.從官網下載最新版本的require,放在js目錄下,使用script引入頁面:

為了不阻塞頁面渲染,可以把它放在HTML的最底部或改為如下方式:

async屬性表明該文件需異步加載(defer屬性兼容IE)。

2.加載頁面邏輯代碼:

假定代碼文件是main.js,也放在js目錄下,則用如下幾種方式引入:

方式1:

data-main屬性指定網頁程序的主入口,這個文件會第一個被requirejs加載。requirejs默認所依賴的資源都是js,所以可以把main.js簡寫成main。

方式2:

在加載require.js后,通過requirejs加載config配置文件(如有),最后加載主模塊:

require([‘configUrl'],function () { //config.js必須通過requirejs加載才能注冊
 require([moduleAName],function(moduelA){
 //邏輯代碼
 })
});

三、主模塊的寫法

// main.js
  require(['moduleA', 'moduleB', 'moduleC'], function (moduleA, moduleB, moduleC){
    // some code here
  });

require()函數接受兩個參數,第一個參數是一個數組,表示當前模塊所依賴的模塊;第二個參數是一個回調函數,當前面指定的模塊都加載成功后,它將被調用。加載的模塊會以參數形式傳入該回調函數,從而在回調函數內部就可以使用這些模塊(被依賴的模塊有return的值)。

require()異步加載moduleA,moduleB和moduleC,瀏覽器不會失去響應;它指定的回調函數,只有當前面依賴的模塊全部下載并執行對應的回調之后,才會運行。

四、模塊的配置

require.config()方法可以定義模塊的路徑,并以短模塊名的形式進行依賴的定義。該方法可以寫在每個主模塊(main.js)的前面,配合主模塊一起使用。

參數是一個對象,這個對象的paths屬性指定各個模塊的加載路徑。paths可以配置多個路徑,如果遠程cdn庫沒有加載成功,則加載本地的庫。

如果不定義模塊的配置,則在主模塊中的依賴需要寫完整路徑。

在每個頁面按需配置路徑:

require.config({  //注冊模塊的配置,供后面的代碼使用
    baseUrl: '/js/', 
 paths: {
   "jquery":”cdnUrl”, "Jquery/jquery-1.12.0.min"
  "fixheight": "login/fixheight"
 }
 });
 require(['jquery', 'fixheight'], function ($, fixHeight) {
 ...other code; 
 fixHeight.init();
});

或者將config配置作為一個單獨的js文件,然后

require([“configJsUrl”],function(){  //需要在main文件中通過require先異步加載模塊配置
 require([‘ModuleName'],function(Name){
 …other code
 })
})

為了避免每個頁面都要嵌套require,還可以用如下方式:

先創建單獨的config.js文件:

require.config({ //注冊模塊的配置,供后面的代碼使用
 baseUrl: "/js/app/", //其他依賴都是對于此位置的相對路徑
 // 路徑配置
 paths: {
underscore: 'vender/underscore.min',   backbone:'vender/backbone.min'
 jquery: ‘cdnUrl','vender/jquery/jquery-1.12.0.min',
 “模塊短名”:”相對于baseUrl的路徑地址,省略模塊文件的后綴.js”
 },
 // 非AMD模式編寫的類庫需要重新配置
 shim: {
 underscore: {
  exports:'_'
 },
 backbone(短模塊名仍需要定義路徑): {
  exports: 'Backbone',      //類庫輸出的變量名,表明這個模塊被外部調用時的名稱
  deps:['jquery','underscore'] //該模塊的依賴
 }
 },
 urlArgs: "bust=" + document.getElementById('publishDate').attributes['value'].value  //js資源的參數,控制版本刷新緩存
});
define([ 'marionette'], function () { }); //仍是會被執行的js代碼,會依次加載需要的模塊

然后通過如下方式使用:

通過主入口直接將模塊配置注冊到requirejs命名空間中,頁面中后續的require方法無需再注冊,可以直接使用短模塊名進行依賴加載。

如果沒有顯式指定config及data-main,則默認的baseUrl為加載RequireJS的HTML頁面所在目錄。如果指定了data-main而沒有在config中指定根路徑,則該路徑被設為baseUrl。

若想避開"baseUrl + paths"的解析過程,而是直接指定加載某一個目錄下的腳本。可以這樣做:如果一個module ID符合下述規則之一,其ID解析會避開常規的"baseUrl + paths"配置,而是直接將其加載為一個相對于當前HTML文檔路徑的腳本:

?    以 ".js" 結束.

?    以 "/" 開始.

?    包含 URL 協議, 如 "http:" or "https:".

eg. require(['/www/js/app/vender/underscore.min.js'], function (_) {…})

require.js要求,每個模塊是一個單獨的js文件。加載多個模塊就會發出多次HTTP請求,影響網頁的加載速度。因此require.js提供了一個優化工具(r.js),當模塊部署完畢以后,可以用這個工具將多個模塊合并在一個文件中,減少HTTP請求數,但又需要和緩存之間進行取舍。

六、AMD模塊的寫法

require.js加載的模塊,必須按照AMD的規定來寫。即模塊必須采用特定的define()函數來定義,通常返回一個對象,該對象具有供別的模塊使用的方法或屬性;或只執行相關邏輯而無輸出。

七、require.js的相關插件

text插件,允許require.js異步加載txt、css或html等文本資源供js使用,而不需要在script內構建Html字符串。

define(['text!components/multiple/template.html', 'image!cat.jpg'],
 function(template,cat){
 $('body').append($(template));
 document.body.appendChild(cat);
 }
);

注意:

模塊的依賴既可以通過[]引入,也可以在回調函數里通過require()方法引入,效果一樣。因為define方法會通過正則先掃描回調函數中require方法的依賴并下載,然后才執行該回調函數。但此時需要傳入依賴require本身,否則會報錯:

define(function(require){
 var helper=require(‘helpModuleUrI');//也會提前加載該依賴
 …
})

多個模塊先后多次依賴同一個模塊時,該模塊只會被下載并初始化一次,之后require會保持對其的引用供別的模塊再次使用。

區分require方法的執行和回調的執行:

require('config',callBack1);
require('b',callBack2);
// 兩個require方法會立即執行,但callBack的執行順序不確定,取決于下載的順序。
//不同于以下代碼,會嚴格按順序執行
require('config',function(){
 require('b',callBack2)
})

關于“RequireJs怎么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

另外有需要云服務器可以了解下創新互聯建站www.cdcxhl.com,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


當前標題:RequireJs怎么用-創新互聯
分享URL:http://www.xueling.net.cn/article/cdieps.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 91青青草| a级在线| 一区二区三区四区视频在线观看 | 国产成a人亚洲精v品久久网 | 亚洲1区在线观看 | 一边摸一边做爽的视频17国产有奶水 | 2023天天操 | 亚洲人成欧美中文字幕 | 91大神免费视频 | 国产精品一区二区在线观看网站 | 久久午夜精品福利一区二区 | 99999久久久久9国产精品 | 中文字幕一区二区人妻性色 | 国产精品国产免费无码专区不卡 | 国产a一级毛片爽爽影院 | 免费看aaaaa级少淫片 | 97国产在线看片免费人成视频 | 亚洲女在线 | 久久网一区二区三区 | 久久国产最新 | 久久国内偷拍视频 | 99久久精品无码一区二区毛片免费 | 麻豆网站在线看 | 高清国产视频在线 | 日本aa毛片a级毛片免费观看 | 在线看午夜福利片国产 | 午夜影视在线 | 蜜臀免费av | 亚洲三级在线视频 | 免费看成人AA片无码视频吃奶 | 欧美性猛交XXXX | 內射XXX韩国在线观看 | 一级黄色片在线 | 网站av在线 | 好想被狂躁无码视频在线观看 | 天天天干 | 国产精品白浆无码流出免费看 | 99情趣网 | 日韩婷婷| 美女裸体黄网站18禁免费看 | 91情趣视频|