欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端webpack一些常用配置的作用詳解

 更新時(shí)間:2025年04月08日 11:41:49   作者:大嘴史努比  
在前端開發(fā)中Webpack已經(jīng)成為構(gòu)建現(xiàn)代JavaScript應(yīng)用的必備工具,它負(fù)責(zé)模塊的打包和優(yōu)化,這篇文章主要介紹了前端webpack一些常用配置的作用,文中介紹的非常詳細(xì),需要的朋友可以參考下

1. Loader

Loader 用于對(duì)模塊的源代碼進(jìn)行轉(zhuǎn)換。它可以將非 JavaScript 文件(如 CSS、圖片、字體等)轉(zhuǎn)換為 webpack 能夠處理的模塊。

常用 Loader 及其作用

Loader作用
babel-loader將 ES6+ 代碼轉(zhuǎn)換為 ES5,兼容舊版瀏覽器。
css-loader解析 CSS 文件,處理 @import 和 url() 等語(yǔ)法。
style-loader將 CSS 插入到 DOM 中,通過(guò) <style> 標(biāo)簽生效。
sass-loader將 SCSS/SASS 文件編譯為 CSS。
file-loader處理文件(如圖片、字體),將其輸出到構(gòu)建目錄并返回文件路徑。
url-loader類似于 file-loader,但可以將小文件轉(zhuǎn)換為 Base64 URL,減少 HTTP 請(qǐng)求。
ts-loader將 TypeScript 編譯為 JavaScript。
module.exports = {
  module: {
    rules: [
      {
        test: /\.js$/, // 匹配 .js 文件
        exclude: /node_modules/, // 排除 node_modules 目錄
        use: 'babel-loader', // 使用 babel-loader
      },
      {
        test: /\.css$/, // 匹配 .css 文件
        use: ['style-loader', 'css-loader'], // 從右到左執(zhí)行
      },
      {
        test: /\.(png|jpe?g|gif|svg)$/, // 匹配圖片文件
        use: [
          {
            loader: 'url-loader',
            options: {
              limit: 8192, // 小于 8KB 的文件轉(zhuǎn)換為 Base64 URL
              name: 'images/[name].[hash:8].[ext]', // 輸出路徑和文件名
            },
          },
        ],
      },
    ],
  },
};

2. Plugin

Plugin 用于擴(kuò)展 webpack 的功能,可以在打包過(guò)程的各個(gè)階段執(zhí)行自定義操作。與 Loader 不同,Plugin 的功能范圍更廣,比如優(yōu)化資源、管理環(huán)境變量、注入全局變量等。

常用 Plugin 及其作用

Plugin作用
HtmlWebpackPlugin自動(dòng)生成 HTML 文件,并自動(dòng)注入打包后的資源(如 JS、CSS)。
MiniCssExtractPlugin將 CSS 提取為單獨(dú)的文件,而不是嵌入到 JS 中。
CleanWebpackPlugin在每次構(gòu)建前清理輸出目錄,避免舊文件殘留。
DefinePlugin定義全局常量,通常用于區(qū)分開發(fā)環(huán)境和生產(chǎn)環(huán)境。
CopyWebpackPlugin復(fù)制靜態(tài)文件(如圖片、字體)到輸出目錄。
HotModuleReplacementPlugin啟用模塊熱替換(HMR),在不刷新頁(yè)面的情況下更新模塊。
OptimizeCSSAssetsPlugin壓縮和優(yōu)化 CSS 文件。
TerserWebpackPlugin壓縮和優(yōu)化 JavaScript 文件。
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
const webpack = require('webpack');

module.exports = {
  plugins: [
    new HtmlWebpackPlugin({
      template: './src/index.html', // 指定 HTML 模板
      filename: 'index.html', // 輸出的 HTML 文件名
    }),
    new MiniCssExtractPlugin({
      filename: 'css/[name].[contenthash:8].css', // 提取 CSS 到單獨(dú)文件
    }),
    new CleanWebpackPlugin(), // 清理輸出目錄
    new webpack.DefinePlugin({
      'process.env.NODE_ENV': JSON.stringify('production'), // 定義環(huán)境變量
    }),
  ],
};

3. 其他常用配置

1) entry

指定打包的入口文件。

module.exports = {
  entry: './src/index.js', // 單入口
  // 多入口
  entry: {
    app: './src/app.js',
    admin: './src/admin.js',
  },
};

2) output

指定打包后的文件輸出位置和文件名。

module.exports = {
  output: {
    path: path.resolve(__dirname, 'dist'), // 輸出目錄
    filename: 'js/[name].[contenthash:8].js', // 輸出文件名
    publicPath: '/', // 公共路徑(用于 CDN)
  },
};

3) mode

設(shè)置打包模式,可選 development、production 或 none

module.exports = {
  mode: 'production', // 生產(chǎn)模式(默認(rèn)啟用代碼壓縮)
};

4) devServer

配置開發(fā)服務(wù)器,支持熱更新、代理等功能。

module.exports = {
  devServer: {
    contentBase: './dist', // 服務(wù)內(nèi)容目錄
    hot: true, // 啟用熱更新
    port: 8080, // 端口號(hào)
    proxy: {
      '/api': 'http://localhost:3000', // 代理 API 請(qǐng)求
    },
  },
};

5) optimization

配置代碼分割和壓縮優(yōu)化。

module.exports = {
  optimization: {
    splitChunks: {
      chunks: 'all', // 代碼分割
    },
    minimizer: [
      new TerserWebpackPlugin(), // 壓縮 JS
      new OptimizeCSSAssetsPlugin(), // 壓縮 CSS
    ],
  },
};

4. 總結(jié)

  • Loader:用于處理特定類型的文件(如 CSS、圖片、字體等),將其轉(zhuǎn)換為 webpack 能夠處理的模塊。

  • Plugin:用于擴(kuò)展 webpack 的功能,如生成 HTML 文件、提取 CSS、壓縮代碼等。

  • 常用配置entry、output、mode、devServeroptimization 等。

到此這篇關(guān)于前端webpack一些常用配置的作用的文章就介紹到這了,更多相關(guān)前端webpack常用配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js實(shí)現(xiàn)雙人五子棋小游戲

    js實(shí)現(xiàn)雙人五子棋小游戲

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)雙人五子棋小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • JS實(shí)現(xiàn)兩周內(nèi)自動(dòng)登錄功能

    JS實(shí)現(xiàn)兩周內(nèi)自動(dòng)登錄功能

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)兩周內(nèi)自動(dòng)登錄功能的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • 關(guān)于this和self的使用說(shuō)明

    關(guān)于this和self的使用說(shuō)明

    剛接觸python的時(shí)候,最不習(xí)慣的事情,就是每個(gè)方法都要加一個(gè)self。無(wú)論Javascript還是C#,都直接一個(gè)this搞定,干嘛非要加一個(gè)變量self。
    2010-08-08
  • BootStrap 導(dǎo)航條實(shí)例代碼

    BootStrap 導(dǎo)航條實(shí)例代碼

    本文通過(guò)實(shí)例代碼給大家介紹了bootstrap導(dǎo)航條效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧
    2017-05-05
  • js定時(shí)調(diào)用方法成功后并停止調(diào)用示例

    js定時(shí)調(diào)用方法成功后并停止調(diào)用示例

    這篇文章主要介紹了js定時(shí)調(diào)用方法成功后并停止調(diào)用的實(shí)現(xiàn),需要的朋友可以參考下
    2014-04-04
  • JavaScript實(shí)現(xiàn)圖片縮放功能

    JavaScript實(shí)現(xiàn)圖片縮放功能

    本文,我們來(lái)講講如何使用 JavaScript 實(shí)現(xiàn)圖片的縮放,當(dāng)然,我們可以類比到其他的元素,比如視頻的縮放,文中有詳細(xì)的代碼示例,對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-07-07
  • JavaScript實(shí)現(xiàn)簡(jiǎn)單網(wǎng)頁(yè)版計(jì)算器

    JavaScript實(shí)現(xiàn)簡(jiǎn)單網(wǎng)頁(yè)版計(jì)算器

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單網(wǎng)頁(yè)版計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • JavaScript中的this指向和自定義屬性詳解

    JavaScript中的this指向和自定義屬性詳解

    下面小編就為大家?guī)?lái)一篇js中的this指向和自定義屬性。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2021-09-09
  • 詳解Bootstrap創(chuàng)建表單的三種格式(一)

    詳解Bootstrap創(chuàng)建表單的三種格式(一)

    在本章中,我們將學(xué)習(xí)如何使用 Bootstrap 創(chuàng)建表單。Bootstrap 通過(guò)一些簡(jiǎn)單的 HTML 標(biāo)簽和擴(kuò)展的類即可創(chuàng)建出不同樣式的表單,對(duì)bootstrap 表單相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • 微信小程序事件流原理解析

    微信小程序事件流原理解析

    這篇文章主要介紹了微信小程序事件流原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11

最新評(píng)論