中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現webpack圖片轉為base64

發布時間:2021-12-13 13:31:20 來源:億速云 閱讀:441 作者:柒染 欄目:開發技術

這篇文章將為大家詳細講解有關如何實現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

關于如何實現webpack圖片轉為base64就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

金昌市| 邹城市| 开远市| 明光市| 祁门县| 城市| 沐川县| 邳州市| 阿克苏市| 金塔县| 海口市| 陵川县| 盈江县| 大城县| 赣州市| 从江县| 黔东| 绥芬河市| 冕宁县| 清徐县| 辛集市| 乌鲁木齐市| 龙岩市| 得荣县| 桐梓县| 襄樊市| 水城县| 广东省| 济宁市| 长治市| 绥江县| 衡阳市| 岢岚县| 新宁县| 迁西县| 长寿区| 龙泉市| 庄浪县| 绥中县| 双流县| 乌苏市|