webpack圖片轉(zhuǎn)為base64的實(shí)現(xiàn)示例
下載url-loader
yarn add -D url-loader module: { rules: [ { test: /\.(jpeg|jpg|png|svg|gif)$/, use: { loader: 'url-loader', // 默認(rèn)使用的是es6模塊 options: { // 配置 esModule: false, // 使用common.js規(guī)范 outputPath: 'images', // 輸出的文件目錄 name: 'images/[contenthash:4].[ext]', limit: 20*1024 // 小于20k轉(zhuǎn)為base64 } } } ] }
可以看到小圖片被轉(zhuǎn)為base64了
完整的代碼
// webpack是基于node,所以使用module.exports const path = require("path"); let HtmlWebpackPlugin = require("html-webpack-plugin"); // 生成html模板 const { CleanWebpackPlugin } = require("clean-webpack-plugin"); // 每次打包前,清除dist const MiniCssExtractPlugin = require("mini-css-extract-plugin"); // 合并css // const OptimizeCssAssetsWebpackPlugin = require("optimize-css-assets-webpack-plugin") // 壓縮css const CssMinimizerWebpackPlugin = require("css-minimizer-webpack-plugin"); // 最新壓縮css const TerserWebpackPlugin = require("terser-webpack-plugin"); // 壓縮js 代替uglify 因?yàn)閡glifyjs不支持es6語(yǔ)法,所以用terser-webpack-plugin替代uglifyjs-webpack-plugin const webpack = require("webpack"); // 里邊有個(gè)ProvidePlugin,可以提供全局的變量 const commonCssConfig = [ // 公共的css配置 MiniCssExtractPlugin.loader, "css-loader", { loader: "postcss-loader", options: { //css兼容性配置 postcssOptions: { plugins: [[require("postcss-preset-env")()]], }, }, }, ]; // 公共的babel轉(zhuǎn)碼器配置 const babelConfig = { loader: 'babel-loader', options: { presets: [ "@babel/preset-env" ], "plugins": [ ["@babel/plugin-proposal-decorators", { "legacy": true }], ["@babel/plugin-proposal-class-properties"] ] } } // 公共的plugin插件配置 const commonPlugin = [ // html-webpack-plugin new HtmlWebpackPlugin({ template: "./src/index.html", // 指定模板 filename: "index.html", // 指定輸出的文件名 }), // new HtmlWebpackPlugin({ // 多模板 // template: './src/index.html', // 指定模板 // filename: 'main.html', // 指定輸出的文件名 // }), // clean-webpack-plugin new CleanWebpackPlugin(), // 使用這個(gè)插件在每次生成dist目錄前,先刪除dist目錄 // mini-css-extract-plugin new MiniCssExtractPlugin({ // 抽取css放在公共文件夾 filename: "css/[name].[hash:4].css", // 合并css的公共文件 }), // css-minimizer-webpack-plugin new CssMinimizerWebpackPlugin(), // 新版壓縮css // terser-webpack-plugin new TerserWebpackPlugin({ // 壓縮js test: /\.js(\?.*)?$/i, //匹配參與壓縮的文件 parallel: true, //使用多進(jìn)程并發(fā)運(yùn)行 terserOptions: { //Terser 壓縮配置 output: { comments: false }, compress: { // pure_funcs: ["console.log"], // 去除console.log }, }, extractComments: true, //將注釋剝離到單獨(dú)的文件中 }), // 注入全局變量,在全局中使用,不需要引入 new webpack.ProvidePlugin({ $:"jquery" }) ] module.exports = { // 老版壓縮css // optimization: { // minimizer: [new OptimizeCssAssetsWebpackPlugin] // }, // 入口配置 entry: "./src/index.js", // 模式配置 mode: "production", // 指定模式,默認(rèn)是生產(chǎn)模式,開發(fā)模式便于查看代碼 // 出口配置 output: { path: path.resolve(__dirname, "dist"), // __dirname 代表的是根目錄 M:\47-webpack-study\01-webpack\dist filename: "js/[name].[hash:4].js", // 指定輸出的文件名 // [name]是動(dòng)態(tài)名字,加上hash值,避免緩存,默認(rèn)是20位的hash值 /* hash的作用: 比如第一次打包的時(shí)候,文件會(huì)被瀏覽器緩存下來(lái) 第二次打包的時(shí)候,如果文件名不變,瀏覽器不會(huì)下載最新的代碼,所以hash就有作用了 hash也叫做內(nèi)容hash值,只要內(nèi)容發(fā)生該變,hash就會(huì)變,就不會(huì)被緩存下來(lái),時(shí)刻保持更新的狀態(tài) */ }, // webpack-dev-server配置 devServer: { host: "localhost", // 主機(jī) port: "9527", // 端口 open: true, // 自動(dòng)打開 historyApiFallback: true, //找不到頁(yè)面默認(rèn)跳index.html compress: true, //一切服務(wù)都啟用gzip 壓縮 hot: true, //啟動(dòng)熱更新 proxy: { // 代理配置 "/api": { target: "http:localhost:5000", changeOrigin: true, }, }, }, // 裝載器配置 module: { rules: [ { test: /\.html$/, use: 'html-withimg-loader', //在html中使用圖片的插件 }, { test: /\.js$/, use: babelConfig // babel轉(zhuǎn)碼器配置 }, { test: /\.css$/, use: [...commonCssConfig], // css順序是從右到左,從下到上 }, { test: /\.less$/, use: [...commonCssConfig,'less-loader'], // less順序是從右到左,從下到上 }, { test: /\.scss$/, use: [...commonCssConfig,"sass-loader"], // sass順序是從右到左,從下到上 }, // { // test: /\.(jpeg|jpg|png|svg|gif)$/, // use: { // loader: 'file-loader', // 默認(rèn)使用的是es6模塊 // options: { // 配置 // esModule: false, // 使用common.js規(guī)范 // outputPath: 'images', // 輸出的文件目錄 // name: 'images/[contenthash:4].[ext]', // } // } // } { test: /\.(jpeg|jpg|png|svg|gif)$/, use: { loader: 'url-loader', // 默認(rèn)使用的是es6模塊 options: { // 配置 esModule: false, // 使用common.js規(guī)范 outputPath: 'images', // 輸出的文件目錄 name: 'images/[contenthash:4].[ext]', limit: 20*1024 // 小于20k轉(zhuǎn)為base64 } } } ], }, // 插件配置 plugins: [...commonPlugin], // 排除第三方包 externals: { jquery: '$', } };
Webpack中設(shè)置圖片不轉(zhuǎn)base64格式
在開發(fā)過程中,圖片轉(zhuǎn)成base64是常有的事,如上傳圖片,但是有些情況下確不希望將圖片轉(zhuǎn)成base64,因?yàn)檗D(zhuǎn)成base64后圖片不容易區(qū)分,也就不能根據(jù)圖片名稱去做一些其它的操作,那么如何才能在Webpack中禁止圖片轉(zhuǎn)成base64呢?
其實(shí)很簡(jiǎn)單,只需要修改Webpack的配置文件webpack.base.conf.js即可,將里面module下的rules中的圖片處理的 options 的 limit改為1,如下圖所示。
到此這篇關(guān)于webpack圖片轉(zhuǎn)為base64的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)webpack圖片轉(zhuǎn)為base64內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js實(shí)現(xiàn)簡(jiǎn)單的前端分頁(yè)效果
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)簡(jiǎn)單的前端分頁(yè)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08javascript 易錯(cuò)知識(shí)點(diǎn)實(shí)例小結(jié)
這篇文章主要介紹了javascript 易錯(cuò)知識(shí)點(diǎn),結(jié)合實(shí)例形式總結(jié)分析了javascript 對(duì)象屬性、繼承常見易錯(cuò)知識(shí)點(diǎn)與注意事項(xiàng),需要的朋友可以參考下2020-04-04javascript常見數(shù)字進(jìn)制轉(zhuǎn)換實(shí)例分析
這篇文章主要介紹了javascript常見數(shù)字進(jìn)制轉(zhuǎn)換,結(jié)合實(shí)例形式分析了JavaScript十進(jìn)制,十六進(jìn)制及二進(jìn)制的相互轉(zhuǎn)換原理與技巧,需要的朋友可以參考下2016-04-04JavaScript Title、alt提示(Tips)實(shí)現(xiàn)源碼解讀
我們知道給某些HTML標(biāo)簽加上title屬性后,這個(gè)標(biāo)簽對(duì)象在瀏覽的時(shí)候,鼠標(biāo)移上去就會(huì)有一個(gè)小提示框出來(lái),并顯示title定義的內(nèi)容。2010-12-12JavaScript Date對(duì)象應(yīng)用實(shí)例分享
這篇文章主要分享了JavaScript Date對(duì)象應(yīng)用實(shí)例,獲取日期時(shí)間,倒計(jì)時(shí)功能實(shí)現(xiàn),限時(shí)搶購(gòu)活動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10javascript innerText和innerHtml應(yīng)用
innerText和innerHtml看字面也應(yīng)該理解的了2010-01-01“不能執(zhí)行已釋放的Script代碼”錯(cuò)誤的原因及解決辦法
“不能執(zhí)行已釋放的Script代碼”錯(cuò)誤的原因及解決辦法...2007-09-09