webpack學習---使用webpack打包圖片檔案
阿新 • • 發佈:2021-10-20
5.使用webpack打包頁面和樣式表中的圖片檔案 需要新增loader配置(module) npm下載 url-loader file-loader html-loader 模組
const { resolve } = require('path'); const HtmlWebpackPlugin = require('html-webpack-plugin'); module.exports = { entry: './src/index.js', output: { filename:'built.js', path: resolve(__dirname, 'build') }, module: { rules: [ { test: /\.less$/, // 要使用多個loader處理用use use: ['style-loader', 'css-loader', 'less-loader'] }, {// 問題:預設處理不了html中img圖片 // 處理圖片資源 test: /\.(jpg|png|gif)$/, // 需要一個type 否則會出現問題 type: 'javascript/auto', // 使用一個loader // 下載 url-loader file-loader loader: 'url-loader', options: {// 圖片大小小於8kb,就會被base64處理 // 優點: 減少請求數量(減輕伺服器壓力) // 缺點:圖片體積會更大(檔案請求速度更慢) limit: 8 * 1024, // 問題:因為url-loader預設使用es6模組化解析,而html-loader引入圖片是commonjs // 解析時會出問題:[object Module] // 解決:關閉url-loader的es6模組化,使用commonjs解析 esModule: false, // 給圖片進行重新命名 // [hash:10]取圖片的hash的前10位 // [ext]取檔案原來副檔名 name: '[hash:10].[ext]' } }, { test: /\.html$/, // 處理html檔案的img圖片(負責引入img,從而能被url-loader進行處理) loader: 'html-loader' } ] }, plugins: [ new HtmlWebpackPlugin({ template: './src/index.html' }) ], mode: 'development' };