[WEBPACK] Webpack series (ep3) - code splitting - chia code trong webpack (ok)
https://viblo.asia/p/webpack-series-ep3-code-splitting-chia-code-trong-webpack-yMnKMyRzK7P
Ví dụ 1: khi chưa sử dụng splitChunks
C:\Users\Administrator\Desktop\demo\package.json
C:\Users\Administrator\Desktop\demo\webpack.config.js
C:\Users\Administrator\Desktop\demo\src\index.js
C:\Users\Administrator\Desktop\demo\src\lib.js
Kết quả sau khi sinh ra
C:\Users\Administrator\Desktop\demo\dist\index.html
Ví dụ 2: khi đã sử dụng splitChunks
C:\Users\Administrator\Desktop\demo\webpack.config.js
C:\Users\Administrator\Desktop\demo\package.json
C:\Users\Administrator\Desktop\demo\src\index.js
C:\Users\Administrator\Desktop\demo\src\lib.js
C:\Users\Administrator\Desktop\demo\src\another.js
Kết quả :)
Xem thêm khi tạo file another như sau :)
C:\Users\Administrator\Desktop\demo\src\another.js
C:\Users\Administrator\Desktop\demo\src\lib.js
C:\Users\Administrator\Desktop\demo\src\index.js
Nếu sử dụng C:\Users\Administrator\Desktop\demo\webpack.config.js
Webpack series (ep3) - code splitting - chia code trong webpack
Code splitting là gì?
Code splitting có thể là một trong những feature thuyết phục nhất của Webpack, nó cho phép chúng ta chia nhỏ code ra nhiều bundle nhỏ hơn, những cái mà chúng ta có thể tải khi cần hoặc để tải song song. Nó thường được sử dụng để tạo ra những bundle code nhỏ hơn cũng như quản lý vấn đề ưu tiên tải tài nguyên, caí nào tải trước, cái nào tải sau, cái nào tải sau cái nào. Nếu sử dụng đúng cách nó có thể tác động lớn đến tốc độ và thời gian tải.
Có 3 cách tiếp cận để split code hiện tại:
Entry point: Phân chia thủ công bằng cách cấu hình file
entry
, file để bắt đầu chạy ứng dụng và từ đó webpack hoạt độngPrevent duplication (ở webpack 4.0 là
splitChunks
): Sử dụngCommonsChunkPlugin
để xóa những bundle trùng lắp và split ra cácchunks
, hiểu nôm na plugin này sẽ giúp loại bỏ việc split ra 2 hoặc nhiều hơn các bundle khác nhau.Dynamic Imports: Chia code thông qua các function được gọi trong các modules.
Entry point
Đây là cách đơn giản nhất, trực quan về cách phân chia code. Chúng ta chỉ cần chỉ rõ ra các entries và webpack sẽ dựa vào đó và tạo ra các bundle tương ứng. Mặc dù vậy cách này khá thủ công và cũng tiềm ẩn những rủi ro không hay mà chúng sẽ gặp phải, giờ chúng ta thử cài đặt nào.
Giả sử máy chúng ta chưa hề cái webpack từ trước nhé.
npm i
là short command củanpm install
-g
là install global
Project
Chúng ta sẽ implement index.js và lib.js đều sử dụng hàm của lodash
index.js
lib.js
webpack.config.js
Run webpack -d
Như đã nói ở trên cách này có những tiềm ẩn rủi ro là:
index.bundle.js
vàlib.bundle.js
đều sử dụng thư việnlodash
và vì do nó là haientry
riêng biệt nên bọn nó không liên quan cũng như không biết thằng còn lại làm gì và cần gì? Nên ai cần cái gì thì import cái đó "chuyện anh anh làm chuyện tui tui làm" do đó 2 bundle đều import thư viện lodash, và đương nhiên cách này là không hề tốt chút nào nếu chúng ta không cẩn thận...Nên nếu muốn làm manual như cách này, tốt nhất chỉ nên có một entry nhận import và các entry khác chỉ import từ entry lib này. Ví dụ
lib.js
sẽ exportlodash
vàindex.js
sẽ import cái này để xài, nhưng như vậy là không hay tẹo nào, nói chung khá là không thoải mái vì "ta thích gì ở đâu thì ta import vào xài không cần phải phụ thuộc thằng nào đã export expiet gì chưa?".Cách này manual nên đương nhiên nó sẽ không linh hoạt để phân chia code một cách tự động.
Và để giải quyết vấn đề của entry point chúng ta sẽ áp dụng Prevent duplication bằng cách dùng CommonsChunkPlugin https://webpack.js.org/plugins/commons-chunk-plugin/
Prevent Duplication
CommonChunkPlugin
cho phép chúng ta extract ra những hàm, thư viện,... chung vào một entry nào đó hoặc đưa ra 1 chunk mới nào đó. Sử dụng nó để hủy sự trùng lắp trong việc sử dụng thư viện lodash
.
Thêm CommonChunkPlugin
vào phần plugins
. webpack.config.js
Run thử nào webpack -d
Với CommonsChunkPlugin
chúng ta thấy sự trùng lặp trong việc gọi thư viện lodash
trong index.js
và lib.js
đã được giải quyết bằng việc tạo ra một bundle mới gọi là common
, và hai enties của chúng ta đã gọi thư viện lodash
trực tiếp từ module common
này.
Chú ý: từ
webpack version 4
thì webpack đã remove pluginCommonsChunkPlugin
thay vào đó làoptimization.splitChunks
, nếu bạn nào bắt đầu sử dụngWebpack
ngay thời điểm (version 4) này thì follow theo cách này. Theo như tài liệu của webpack thìoptimization.splitChunks
có nhiều điểm cải tiến hơnCommonsChunkPlugin
là:
Ít sinh ra code hơn
Cache tốt hơn
Chia nhỏ common chunk hơn => download ít và nhẹ hơn
Bấy giờ chúng ta thêm một file mới là another.js
, sau đó cài đặt jquery
và sử dụng nó trong cả index.js
và another.js
another.js
index.js
Update lại webpack.config.js
Run webpack -p
Chúng ta thấy các nó chia nhỏ các common chunk ra:
vendors~another~index.bundle.js
:index.js
vàanother.js
sẽ dùng chung, nó chứa source củajquery
vendors~index~lib.bundle.js
:index.js
vàlib.js
dùng chung, chứa source củalodash
Rõ ràng ở mức này việc chia nhỏ code của dự án chúng ta như thế này tưởng đối có thể sử dụng được, nhưng với những dự án lớn hơn, phức tạp hơn cũng như cần sự linh động của việc chia code hơn chúng ta sẽ đi tới phần cuối cùng.
Dynamic Imports
Theo như spec của webpack
thì họ support hai kỹ thuật tương tự nhau để chia code tự động là:
import()
syntax dựa theo ECMAScript proposal (hàng ngoại nhập theo xu hướng thị trường) - support từ ver 2.xxx (xxx ko nhớ)require.ensure
systax của webpack định nghĩa ra (hàng nội) - support từ ver1
sử dụng import()
import()
Cập nhât lại các files
another.js
index.js
Chúng ta sẽ dùng jquery tạo một button và sau khi click button đó, thì sẽ tải module another.js
và kèm đó là lodash
, sau đó sử dụng hàm join
của lodash
và execute
State của việc này sẽ là như thế này:
load
index.js
và vendor của nó làvendor~index.js
người dùng click button
load
another.bundle.js
vàvendors~another.bundle.js
chứa source củalodash
và sử dụng hàmjoin
, sau đó tạo ra 1 thẻ<span>
và append vào body.
webpack.config.js
Run webpack -p
Các bạn có thể vào dist/index.html
để chạy thử
Bài viết gốc: https://www.jinhduong.com/2018/04/03/webpack-series-code-splitting/
Phần 1: https://www.jinhduong.com/2017/04/20/2017-04-20-webpack-co-ban/
Phần 2: https://www.jinhduong.com/2017/04/21/2017-04-21-webpack-co-ban-2/
Thanks for watching !
Last updated