[WEBPACK] Webpack từ A đến Á: Webpack Url Loader (ok)
https://viblo.asia/p/webpack-tu-a-den-a-webpack-url-loader-L4x5x3MqlBM
Last updated
https://viblo.asia/p/webpack-tu-a-den-a-webpack-url-loader-L4x5x3MqlBM
Last updated
Ví dụ đã hoàn thành:
C:\xampp\htdocs\abc\package.json
C:\xampp\htdocs\abc\webpack.config.js
C:\xampp\htdocs\abc\dist\index.html
C:\xampp\htdocs\abc\src\index.js
Trong bài hướng dẫn này chúng ta sẽ tìm hiểu cách thiết lập Webpack để sử dụng hình ảnh trong ứng dụng của bạn thông qua url-loader, nó giúp chúng ta mã hóa hình ảnh thành chuỗi base64 URIs, cùng tìm hiểu xem cách load hình ảnh vào Javascript như thế nào.
Code file dist/index.html
Trong folder src
ta để ảnh muốn import bên trong folder assets (tài nguyên) như cấu trúc bên dưới
url-loader giúp chúng ta mã hóa các file thành chuỗi base64. url-loader hoạt động giống với file-loader nhưng có thể trả về DataURL nếu tệp nhỏ hơn giới hạn byte. Để sử dụng chúng ta phải cài đặt nó thông qua npm
Sau khi cài đặt xong chúng ta chỉnh sửa lại cấu hình file webpack.config.js
. Các tài nguyên hình ảnh có đuôi là png | jpg | gif sẽ được load thông qua url-loader.
Code file src/index.js
Ý nghĩa đoạn code trên là tạo ra một thẻ img có src là đường dẫn bức ảnh ở phần import, alt là mô tả bức ảnh. Sau khi tạo xong thì chèn ảnh này vào trong thẻ HTML có id là root.
Thế là xong phần cấu hình giờ chúng ta chạy webpack xem thế nào: npm run dev
Bây giờ chúng ta chạy file dist/index.html
và xem code trong F12
Ta thấy đường dẫn bức ảnh lúc này là một chuỗi base64 rất dài và đó chính là tác dụng của url-loader. Nếu bạn muốn tìm hiểu base64 là gì, những điểm lợi và hại khi sử dụng nó thì có thể tham khảo link này để đọc thêm: http://blogchubang.blogspot.com/2016/09/base64-image-o-la-gi-va-can-luu-y-nhung.html
Giới hạn dung lượng file, mặc định là no limit. Nếu kích thước tệp bằng hoặc lớn hơn giới hạn, webpack sử dụng file-loader
(theo mặc định) và tất cả các tham số truy vấn được chuyển cho nó. Ví dụ dưới đây giới hạn dung lượng tối đa là 8KB
Bài viết đến đây là hết, hi vọng với bài viết này các bạn đã thêm được nhiều kiến thức bổ ích. Hẹn gặp lại các bạn ở bài viết tiếp theo!
Tham khảo thêm các cấu hình khác cho url-loader: https://webpack.js.org/loaders/url-loader/
Source code github: https://github.com/kentrung/webpack-tutorial
All Rights Reserved