webpack图片转为base64的实现示例

下载url-loader

 yarn add -D url-loader
module: {
  rules: [
       {
        test: /\\.(jpeg|jpg|png|svg|gif)$/,
        use: {
          loader: \'url-loader\', // 默认使用的是es6模块
          options: { // 配置 
            esModule: false, // 使用common.js规范
            outputPath: \'images\', // 输出的文件目录
            name: \'images/[contenthash:4].[ext]\',
            limit: 20*1024 // 小于20k转为base64
          }
        }
      }
  ]
}

可以看到小图片被转为base64了

webpack图片转为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 因为uglifyjs不支持es6语法,所以用terser-webpack-plugin替代uglifyjs-webpack-plugin

const webpack = require(\"webpack\"); // 里边有个ProvidePlugin,可以提供全局的变量

const commonCssConfig = [ // 公共的css配置
  MiniCssExtractPlugin.loader,
  \"css-loader\",
  {
    loader: \"postcss-loader\",
    options: {
      //css兼容性配置
      postcssOptions: {
        plugins: [[require(\"postcss-preset-env\")()]],
      },
    },
  },
];
// 公共的babel转码器配置
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(), // 使用这个插件在每次生成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, //使用多进程并发运行
    terserOptions: {
      //Terser 压缩配置
      output: { comments: false },
      compress: {
        // pure_funcs: [\"console.log\"], // 去除console.log
      },
    },
    extractComments: true, //将注释剥离到单独的文件中
  }),
  // 注入全局变量,在全局中使用,不需要引入
  new webpack.ProvidePlugin({
    $:\"jquery\"
  })
]

module.exports = {
  // 老版压缩css
  // optimization: {
  //   minimizer: [new OptimizeCssAssetsWebpackPlugin]
  // },
  // 入口配置
  entry: \"./src/index.js\",
  // 模式配置
  mode: \"production\", // 指定模式,默认是生产模式,开发模式便于查看代码
  // 出口配置
  output: {
    path: path.resolve(__dirname, \"dist\"), // __dirname 代表的是根目录  M:\\47-webpack-study\\01-webpack\\dist
    filename: \"js/[name].[hash:4].js\", // 指定输出的文件名 // [name]是动态名字,加上hash值,避免缓存,默认是20位的hash值
    /* 
     hash的作用:
     比如第一次打包的时候,文件会被浏览器缓存下来
     第二次打包的时候,如果文件名不变,浏览器不会下载最新的代码,所以hash就有作用了
     hash也叫做内容hash值,只要内容发生该变,hash就会变,就不会被缓存下来,时刻保持更新的状态
    */
  },
  // webpack-dev-server配置
  devServer: {
    host: \"localhost\", // 主机
    port: \"9527\", // 端口
    open: true, // 自动打开
    historyApiFallback: true, //找不到页面默认跳index.html
    compress: true, //一切服务都启用gzip 压缩
    hot: true, //启动热更新
    proxy: {
      // 代理配置
      \"/api\": {
        target: \"http:localhost:5000\",
        changeOrigin: true,
      },
    },
  },
  // 装载器配置
  module: {
    rules: [
      {
        test: /\\.html$/,
        use: \'html-withimg-loader\', //在html中使用图片的插件
       },
      {
        test: /\\.js$/,
        use: babelConfig // babel转码器配置
      },
      {
        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\', // 默认使用的是es6模块
      //     options: { // 配置 
      //       esModule: false, // 使用common.js规范
      //       outputPath: \'images\', // 输出的文件目录
      //       name: \'images/[contenthash:4].[ext]\',
      //     }
      //   }
      // }
      {
        test: /\\.(jpeg|jpg|png|svg|gif)$/,
        use: {
          loader: \'url-loader\', // 默认使用的是es6模块
          options: { // 配置 
            esModule: false, // 使用common.js规范
            outputPath: \'images\', // 输出的文件目录
            name: \'images/[contenthash:4].[ext]\',
            limit: 20*1024 // 小于20k转为base64
          }
        }
      }
    ],
  },
  // 插件配置
  plugins: [...commonPlugin],
  // 排除第三方包
  externals: {
    jquery: \'$\',
  }
};

Webpack中设置图片不转base64格式

在开发过程中,图片转成base64是常有的事,如上传图片,但是有些情况下确不希望将图片转成base64,因为转成base64后图片不容易区分,也就不能根据图片名称去做一些其它的操作,那么如何才能在Webpack中禁止图片转成base64呢?

其实很简单,只需要修改Webpack的配置文件webpack.base.conf.js即可,将里面module下的rules中的图片处理的 options 的 limit改为1,如下图所示。

webpack图片转为base64的实现示例

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容