亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

在JavaScript應用中實現延遲加載的方法

2019-11-20 12:09:40
字體:
來源:轉載
供稿:網友

無論簡單還是復雜的Web應用,都由一些HTML、JavaScript、CSS文件組成。通常開發者會通過JQuery、Knockout、Underscore等等這樣的第三方JavaScript框架來提高開發速度。由于這些JavaScript框架都針對特定的用途開發而且已經得到了“驗證”,所以直接使用它們就比自己從頭實現所需要的功能顯得更為合適。然而,伴隨著應用的復雜度不斷上升,寫出干凈、低耦合、可維護的代碼變得越來越重要。在這篇文章里,我將解釋RequireJS框架如何幫助應用開發者寫出更加模塊化的代碼,以及它是如何通過延遲加載JavaScript文件來提高應用性能的。
 開始的部分我們先不用RequireJS框架,然后在下一個章節用RequireJS來重構它。

下面的這個HTML頁面包含了一個id為“message”的<p>元素。當用戶訪問這個頁面的時候,它將展示訂單Id和客戶姓名信息。

Common.JS文件包含了兩個模塊的定義――Order和Customer。函數showData和頁面的body結合在一起,它通過調用write函數來把要輸出的信息放入頁面中。作為示例,我在showData函數里硬編碼了Id為1,客戶姓名為Prasad。

<!DOCTYPE html><html><head><title>JavaScript NonRequireJS</title><script src="common.js" type="text/javascript"></script></head><body><strong>Display data without RequireJS</strong><p id="message" /><script type="text/javascript">showData();</script></body></html>Common.JS
function write(message) {  document.getElementById('message').innerHTML += message + '</br>';} function showData() {  var o = new Order(1, "Prasad");  write("Order Id : " + o.id + " Customer Name : " + o.customer.name);} function Customer(name) {  this.name = name;  return this;} function Order(id, customerName) {  this.id = id;  this.customer = new Customer(customerName);  return this;}

在瀏覽器中打開這個頁面,你將看到如下的信息。

201562590347564.png (300×172)

雖然上面的代碼能夠顯示輸出,但是它仍有一些問題:

  •     Common.JS文件包含了所有需要定義的函數(write,showData),而且模塊(Order,Customer)很難維護和復用。假如你想在其它頁面里復用write函數并引用了上面的JavaScript文件,那么你也導入了這個頁面可能不需要的其它函數和模塊。
  •     Order模塊(或者在面向對象中叫做“類”)在初始化過程中創建了一個Customer模塊的實例。這意味著Order模塊依賴于Customer模塊。這些模塊間的緊耦合使得將來在優化時很難重構與維護。
  •     每當客戶端請求這個頁面時,Common.JS文件就會被載入DOM。在上面這個例子中,盡管我們只需要在頁面上輸出信息,但我們仍把那些不需要的模塊(Customer,Order)載入了內存。載入不必要的應用資源(JavaScript、CSS、圖片文件等等)會降低應用的性能。
  •     Common.JS文件里的模塊可以被分離到不同的JavaScript文件里,但是當應用變得越來越復雜時,很難判斷JavaScript文件之間的依賴關系與需要被加載的文件的加載順序。

RequireJS框架處理了JavaScript文件間的依賴關系,并且根據需要按順序加載它們。

用RequireJS搭建應用

現在讓我們看看重構過的代碼。下面的HTML代碼引用了Require.JS文件。data-main屬性定義了這個頁面的唯一入口點。在下面這個場景中,它告訴了RequireJS在啟動的時候加載Main.js。
 

<!DOCTYPE html><html><head><title>JavaScript RequireJS</title><script src="Require.Js" type="text/javascript" data-main="Main.js"></script></head><body><strong>Display data using RequireJS</strong><p id="message" /></body></html>

 Main.JS

由于這個文件已經通過data-main屬性指定,RequireJS將會盡快的加載它。這個文件使用了RequireJS框架的函數來確定和定義對于其它JavaScript文件的依賴關系。在下面的代碼片段里,第一個參數表示依賴關系(依賴Order.JS文件),第二個參數為一個回調函數。RequireJS分析所有的依賴關系并載入它們,然后執行這個回調函數。請注意,第一個參數的值(Order)必須和文件名一致(Order.JS)。

require(["Order"], function (Order) {  var o = new Order(1, "Prasad");  write(o.id + o.customer.name);});

 Order.JS

RequireJS框架提供了一個定義和維護JavaScript文件間依賴關系的簡便途徑。下面代碼中的define函數聲明了Customer.JS必須在處理Order回調函數前載入。

define(["Customer"],function (Customer) {function Order(id, custName) {this.id = id;this.customer = new Customer(custName);}return Order;});

Customer.JS

這個文件不依賴于任何其它JavaScript文件,所以define函數的第一個參數的值是一個空數組。

define([],function () {function Customer(name) {this.name = name;}return Customer;});

好了,現在用你的瀏覽器打開這個應用,你將會看到如下的輸出。要注意的是RequireJS只載入了必需的JavaScript文件。

201562590435120.png (300×172)

 總結

在這篇文章里,我們分析了RequireJS框架是如何處理JavaScript文件間的依賴關系并根據需要載入它們的。它能夠幫助開發者寫出更松耦合、更模塊化且更具有可維護性的代碼。

謝謝

下載源代碼: Lazy Loading using RequireJS (Prasad Honrao, Codetails)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产激情久久久| 成人黄色av网站| 91视频免费在线| 色偷偷av一区二区三区| 日韩视频亚洲视频| 亚洲成人免费在线视频| 久久99热精品这里久久精品| 日本久久91av| 中文字幕亚洲欧美日韩在线不卡| 91美女福利视频高清| 91免费视频国产| 国产精品自产拍在线观看| 欧美午夜视频一区二区| 色综合色综合久久综合频道88| 亚洲一区二区三区毛片| 色妞久久福利网| 日韩电影在线观看中文字幕| 一区二区三区黄色| 久久久噜噜噜久久中文字免| 欧美成人精品xxx| 亚洲网站视频福利| 中文字幕日韩欧美在线视频| 久热精品在线视频| 欧美主播福利视频| 最近2019年日本中文免费字幕| 97超级碰碰人国产在线观看| 亚洲伊人久久综合| 亚洲精品91美女久久久久久久| 亚洲石原莉奈一区二区在线观看| 日韩欧美在线视频观看| 黑人与娇小精品av专区| 26uuu另类亚洲欧美日本老年| 国产视频亚洲精品| 亚洲国产精品国自产拍av秋霞| 国产午夜精品美女视频明星a级| 国产精品国内视频| 日韩在线观看高清| 久久久久久亚洲精品不卡| 成人精品视频久久久久| 亚洲尤物视频网| 欧美黑人xxxx| 欧美大片免费看| 欧美日韩精品中文字幕| 亚洲第一页中文字幕| 国产精品女主播| 免费91麻豆精品国产自产在线观看| 亚洲人成电影网| 色偷偷偷综合中文字幕;dd| 精品久久久香蕉免费精品视频| 国产精品成人久久久久| 国产免费一区二区三区香蕉精| 国产在线98福利播放视频| 久久久久久久久国产精品| 精品视频在线播放| 国产91在线高潮白浆在线观看| 国内精品视频一区| 成人免费网站在线看| 国产成人亚洲综合91| 国产视频精品在线| 久久久精品2019中文字幕神马| 亚洲国产精品国自产拍av秋霞| 亚洲一区二区三区久久| 亚洲综合国产精品| 亚洲日韩中文字幕| 久久成人精品一区二区三区| 国产精品成人av性教育| 欧美黄色免费网站| 久久久久久国产精品美女| 姬川优奈aav一区二区| 国产一区在线播放| 欧美日韩在线观看视频| 欧美激情亚洲另类| 色老头一区二区三区在线观看| 韩曰欧美视频免费观看| 97久久久免费福利网址| 亚洲欧美999| 亚洲欧美在线播放| 亚洲国产日韩欧美在线99| 久久影院免费观看| 日韩小视频在线观看| 人人澡人人澡人人看欧美| 91免费精品视频| 欧美精品久久一区二区| 亚洲欧美日韩一区二区三区在线| 91久久精品美女| 精品久久久久久久中文字幕| 国产精品一香蕉国产线看观看| 美女性感视频久久久| 中文日韩在线观看| 91九色在线视频| 综合网日日天干夜夜久久| 爽爽爽爽爽爽爽成人免费观看| 影音先锋日韩有码| 亚洲色图第三页| 色偷偷88888欧美精品久久久| 欧美视频13p| 亚洲国产精品福利| 亚洲欧美国产精品专区久久| 国产精品第3页| 国产91成人在在线播放| 国产精品a久久久久久| 亚洲情综合五月天| 成人激情在线播放| 欧美一区二区三区四区在线| 国产成人精品电影久久久| 97视频com| www.久久久久久.com| 91精品国产91| 17婷婷久久www| 亚洲欧美日本伦理| 欧美午夜精品久久久久久人妖| 亚洲高清久久久久久| 欧美在线一级va免费观看| 久99久在线视频| 久久91精品国产91久久久| 久久久电影免费观看完整版| 亚洲高清一二三区| 丁香五六月婷婷久久激情| 欧美另类在线观看| 欧美大片在线免费观看| 亚洲国产成人一区| 欧美午夜影院在线视频| 永久免费毛片在线播放不卡| 欧美精品制服第一页| 欧美超级免费视 在线| 欧美日韩免费网站| 国产精品成av人在线视午夜片| 欧美亚洲伦理www| 日韩av在线免费看| 久热爱精品视频线路一| 91国在线精品国内播放| 欧美高清自拍一区| 欧美日韩国产综合视频在线观看中文| 亚洲欧美日韩国产中文| 91精品视频免费看| 久久这里只有精品99| 亚洲自拍小视频| 日韩欧美精品中文字幕| 国产精品日韩久久久久| 成人精品视频在线| 亚洲精品自产拍| 热re99久久精品国产66热| 欧美电影院免费观看| 2018中文字幕一区二区三区| 欧美在线视频播放| 久久久精品久久| 欧美精品videossex88| 81精品国产乱码久久久久久| 日韩欧美亚洲成人| 久久精品夜夜夜夜夜久久| 欧美激情一区二区三区在线视频观看| 久久精品中文字幕一区| 国产亚洲精品久久久久动| 欧美裸体xxxx极品少妇软件| 国产亚洲一区二区在线| 精品国产成人在线| 国产精品久久久久久久久男| 亚洲欧美综合区自拍另类| 成人免费看黄网站| 中文字幕视频在线免费欧美日韩综合在线看| 国产精品白丝av嫩草影院| 国产日韩av高清| 亚洲国产日韩欧美综合久久| 九九精品在线观看|