溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

webpack中代碼分割和按需加載有什么用

發(fā)布時(shí)間:2021-07-16 09:44:49 來源:億速云 閱讀:152 作者:小新 欄目:web開發(fā)

小編給大家分享一下webpack中代碼分割和按需加載有什么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

為什么需要代碼分割和按需加載

代碼分割就是我們根據(jù)實(shí)際業(yè)務(wù)需求將代碼進(jìn)行分割,然后在合適的時(shí)候在將其加載進(jìn)入文檔中。

舉個(gè)簡(jiǎn)單的例子:

1.一個(gè)HTML中存在一個(gè)按鈕

2.點(diǎn)擊按鈕出現(xiàn)一個(gè)包著圖片的div

3.點(diǎn)擊關(guān)閉按鈕圖片消失

Demo目錄:

webpack中代碼分割和按需加載有什么用

一.當(dāng)未點(diǎn)擊按鈕時(shí)瀏覽器只加載了對(duì)入口文件打包后的js

webpack中代碼分割和按需加載有什么用

二.點(diǎn)擊按鈕會(huì)對(duì)組件進(jìn)行異步加載

webpack中代碼分割和按需加載有什么用

這個(gè)clichunk就是我們打包好的click組件,包括相應(yīng)的JS邏輯html和css

例子源碼記錄

1.編輯入口文件

window.onload=function(){
     var _cs=require('./index.css');
     var $=require('jquery');

     $('#_click').on('click',function(){
       require.ensure([],function(require){
         var _click=require('./_clickWindow.js');
         if(!_clickEvent){
           console.log(_click);
           var _clickEvent=_click._clicks;
         }
         new _clickEvent();
       },'cli')
     });
};

webpack將一切視為模塊,CSS,js,html,JSX等等。

var _cs=require('./index.css');

引入對(duì)應(yīng)的css模塊。這就需要我們安裝css-loder和style-loader。

webpack中代碼分割和按需加載有什么用 

–save -dev的目的是為了在package.json文件的devDependencies寫入依賴項(xiàng)。

點(diǎn)擊按鈕時(shí),加載定義好的組件,當(dāng)加載完成后執(zhí)行組件里的方法。

首先要學(xué)習(xí)require.ensure方法:

在commonjs中有一個(gè)Modules/Async/A規(guī)范,里面定義了require.ensure語法。webpack實(shí)現(xiàn)了它,作用是可以在打包的時(shí)候進(jìn)行代碼分片,并異步加載分片后的代碼。用法如下:

require.ensure([], function(require){
  var list = require('./list');
  list.show();
});

中括號(hào)內(nèi)寫入依賴項(xiàng)

此時(shí)list.js會(huì)被打包成一個(gè)單獨(dú)的chunk文件,大概長這樣:

1.fb874860b35831bc96a8.js。

可讀性比較差,此時(shí)就需要加入第三個(gè)參數(shù)

require.ensure([], function(require){
  var list = require('./list');
  list.show();
}, 'list');

此時(shí)打包后的js文件名為

list.fb874860b35831bc96a8.js

也可以傳入像”question/list”這樣帶層級(jí)的名字,這樣webpack會(huì)按照層級(jí)給你創(chuàng)建文件夾。

require.ensure([], function(require){
  var list = require('./list');
  list.show();
  var edit = require('./edit');
  edit.display();
}, 'list_and_edit');

同時(shí)引入兩個(gè)文件,webpack會(huì)將這兩個(gè)文件和寫入的依賴項(xiàng)打包在一起,如果你不希望打包在一起,只能寫兩require.ensure分別引用這兩個(gè)文件。

require.ensure([‘./a.js'], function(require){
  var list = require('./list');
  list.show();
});

require.ensure([‘./a.js'], function(require){
  var b = require('./b');
  b.show();
});

如果list和b同時(shí)以來a.js那么在打包時(shí)a.js會(huì)被重復(fù)打包兩次,如果想解決這樣的問題,那么

require.ensure([‘./a.js'], function(require){
  var list = require('./list');
  list.show();
},'list-b');

require.ensure([‘./a.js'], function(require){
  var b = require('./b');
  b.show();
},'list-b');

此時(shí)這三個(gè)文件就會(huì)被打包在一起。

2.組件js

(function(){
  var _html=require('./_clickHtml.html');
  var $=require('jquery');

  function ClickWindow(){
   this.div=$('body').append(_html);
   $('#_tip').append('<img src="./timg.jpg">');
   this.init();
  }
  ClickWindow.prototype.init=function(){
   $('#_tip').append('<button>關(guān)閉</button>')
     .on('click',function(){
       $('img').animate({'width':0},300);
     });
  };

  module.exports._clicks=ClickWindow;
})();

引入寫好的html同上需要下載html-loader

3.配置文件

var path=require('path');
module.exports={
 entry:__dirname+'/index.js',
 output:{
   path: __dirname,
   filename:'[name]bundle.js',
   chunkFilename:'[name]chunk.js'
 },
  module: {
      loaders: [  //加載器
       {test: /\.css$/, loader: "style!css" },
       {test: /\.html$/, loader: "html" },
       {test: /\.(png|jpg)$/, loader: 'url-loader?limit=8192'}
      ]
  }
};

filename:'[name]bundle.js',

[name]指向入口文件的name

chunkFilename:'[name]chunk.js'

[name]指向require.ensure定義的第三個(gè)參數(shù)

以上是“webpack中代碼分割和按需加載有什么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI