自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

好記性不如爛筆頭-Webpack篇

開發(fā) 前端
指示webpack如何去輸出、以及在哪里輸出你的bundle、asset 和其他你所打包或使用 webpack載入的任何內(nèi)容。

 

[[439403]]

一、Entry

定義:指示webpack應(yīng)該使用哪個(gè)模塊,來作為構(gòu)建其內(nèi)部依賴圖的開始。(從入口開始,搜尋并遞歸解析出所有入口依賴的模塊)

1.1 單入口

對于單入口文件,其值為string類型,打包形成一個(gè)chunk,輸出一個(gè)bundle文件。

  1. module.exports = { 
  2.  
  3. entry: './src/index.js' 
  4.  

1.2 多入口

輸入為一個(gè)數(shù)組,但是入口文件最終只會形成一個(gè)chunk,輸出出去只有一個(gè)bundle文件。

  1. module.exports = { 
  2.  
  3. entry: ['./src/index.js','./src/add.js'
  4.  

輸入為對象,有幾個(gè)入口文件就形成幾個(gè)chunk,輸出幾個(gè)bundle1文件

  1. module.exports = { 
  2.     entry: { 
  3.         index'./src/index.js'
  4.         add'./src/add.js'
  5.     } 

1.3 動(dòng)態(tài)入口

輸入為一個(gè)函數(shù)(同步或異步),用于動(dòng)態(tài)的返回上面所需的入口內(nèi)容。

  1. module.exports = { 
  2.  
  3. entry: () => new Promise((resolve) => resolve(['./src/index.js','./src/add.js'])) 
  4.  

二、Output

指示webpack如何去輸出、以及在哪里輸出你的bundle、asset 和其他你所打包或使用 webpack載入的任何內(nèi)容。

2.1 名稱

對于輸出的名字,常用的主要有兩類:filename(輸出bundle名稱)和chunkFilename(非入口chunk名稱)。

filename(配置輸出文件的名稱,為string類型)

  1. module.exports = { 
  2.     //文件名稱(指定名稱+目錄) 
  3.     filename: '[name].js' 

chunkFilename(配置非入口chunk的名稱)

對于非入口文件,產(chǎn)生方式有兩種:方式一是通過import語法會將一個(gè)文件單獨(dú)分割成一個(gè)chunk;方式二是利用optimization將node_modules分割成chunk。(見后續(xù)博客)

  1. module.exports = { 
  2.     //非入口chunk名稱 
  3.     chunkFilename: '[name]_chunk.js' 

2.2 路徑

對于配置的輸出路徑,常用的主要有兩個(gè):path和publicPath。

path(配置輸出文件存放的目錄,必須是string類型的絕對路徑

  1. module.exports = { 
  2.  
  3. path: path.resolve(__dirname, 'dist_[hash]'
  4.  

publicPath(所有資源引入公共路徑前綴)

  1. module.exports = { 
  2.  
  3. publicPath: 'https://cdn.example.com/' 
  4.  

2.3 輸出庫

當(dāng)用webpack去構(gòu)建一個(gè)可以被其它模塊導(dǎo)入使用的庫時(shí),需要用到libraryTarget和library。其中l(wèi)ibraryTarget配置何種方式導(dǎo)出庫;library配置導(dǎo)出庫名稱。

  1. module.exports = { 
  2.     library: '[name]'
  3.     libraryTarget: 'window',//var、assign、this、window、global、commonjs、commonjs2、amd、umd…… 

三、Loader

webpack只能理解JavaScript和JSON文件,通過loader讓webpack能夠去處理其它類型的文件,并將它們轉(zhuǎn)換為有效 模塊,以供應(yīng)用程序使用,以及被添加到依賴圖中。

3.1 樣式資源

對于css和less這樣的樣式資源,webpack不能直接進(jìn)行處理,所以需要經(jīng)過webpack翻譯后才可以使用。此外不同瀏覽器對CSS的支持不同,為了CSS解決兼容性問題,可借助postcss-loader進(jìn)行處理。

  1. module.export = { 
  2.     …… 
  3.     module: { 
  4.         rules: [ 
  5.             { 
  6.                 test: /\.css$/, 
  7.                 use: [ 
  8.                     //創(chuàng)建style標(biāo)簽,將js中的樣式資源插入到html文件中。 
  9.                     'style-loader'
  10.                     // 將css文件變成commonjs模塊加載到j(luò)s中 
  11.                     'css-loader'
  12.                     'postcss-loader'
  13.                 ] 
  14.             }, 
  15.             { 
  16.                 test: /\.less$/, 
  17.                 use: [ 
  18.                     'style-loader'
  19.                     'css-loader'
  20.                     // 將less文件編譯成css文件 
  21.                     'less-loader'
  22.                 ] 
  23.             } 
  24.         ] 
  25.     } 

3.2 圖片資源

對于圖片資源來說,主要可以分為html中圖片和非html中圖片。對于url-loader或file-loader能夠處理js、css等中的圖片資源,但是不能直接處理html中的圖片資源,所以需要引用html-loader,負(fù)責(zé)引入img,從而能被url-loader進(jìn)行處理。

  1. module.exports = { 
  2.     module: { 
  3.         rules: [ 
  4.             { 
  5.                 test: /\.(png|jpg|gif)$/, 
  6.                 loader: 'url-loader'
  7.                 options: { 
  8.                     limit: 8 * 1024, 
  9.                     name'[hash:10].[ext]'
  10.                     outputPath: 'asset/images' 
  11.                 } 
  12.             }, 
  13.             { 
  14.                 test: /\.html/, 
  15.                 loader: 'html-loader'
  16.             }, 
  17.         ] 
  18.     } 

3.3 js文件

因?yàn)槊總€(gè)人寫代碼的風(fēng)格不同,為了統(tǒng)一js文件的風(fēng)格,規(guī)范代碼,可以采用eslint-loader進(jìn)行處理。

  1. module.exports = { 
  2.     …… 
  3.     module: { 
  4.         rules: [ 
  5.             { 
  6.                 test: /\.js$/, 
  7.                 exclude: /node_modules/, 
  8.                 // 優(yōu)先執(zhí)行 
  9.                 enfore: 'pre'
  10.                 loader: 'eslint-loader'
  11.                 options: { 
  12.                     // fix: true 
  13.                 } 
  14.             } 
  15.         ] 
  16.     } 

此處可以用比較權(quán)威的Airbnb來進(jìn)行語法檢查,需要在package.json中添加:

  1. "eslintConfig": { 
  2.     "extends""airbnb-base"
  3.     "env": { 
  4.       "browser"true 
  5.     } 

不同瀏覽器對js代碼的支持性不同,所以需要對js代碼進(jìn)行兼容性處理,可以利用babel-loader,配置方式主要有三種:

(1) 基本js兼容性處理-->@babel/preset-env

問題:只能轉(zhuǎn)換基本語法,如Promise不能轉(zhuǎn)換

(2)全部js兼容性處理--> @babel/polyfill

對于這個(gè)文件,只需要在js文件中直接引入即可 import '@babel/polyfill'; 這會將js有兼容性的東西全部帶進(jìn)來。

問題:我只要解決部分兼容性問題,但是將所有兼容性代碼全部引入,導(dǎo)致文件體積太大了

(3)需要做兼容性處理的就做:按需加載 --> core-js

此時(shí)要把第二種方案的代碼注釋掉。

  1. module.exports = { 
  2.     …… 
  3.     module: { 
  4.         rules: [ 
  5.             { 
  6.                 test: /\.js$/, 
  7.                 exclude: /node_modules/, 
  8.                 loader: 'babel-loader'
  9.                 options: { 
  10.                     // 預(yù)設(shè):指示babel做怎么樣的兼容性處理 
  11.                     presets: [ 
  12.                         '@babel/preset-env'
  13.                         { 
  14.                             // 按需加載 
  15.                             useBuiltIns: 'usage'
  16.                             // 指定core-js版本 
  17.                             corejs: { 
  18.                                 version: 3 
  19.                             }, 
  20.                             // 指定兼容性做到哪個(gè)版本瀏覽器 
  21.                             targets: { 
  22.                                 chrome: '60'
  23.                                 firefox: '60'
  24.                                 edge: '17'
  25.                                 safari: '10'
  26.                             } 
  27.                         } 
  28.                     ] 
  29.                 } 
  30.             } 
  31.         ] 
  32.     } 

3.4 其它資源

對于不需要進(jìn)行優(yōu)化、壓縮等進(jìn)行處理的文件,例如字體圖標(biāo)、SVG等,可以直接被引入使用,這個(gè)時(shí)候用file-loader直接處理即可。

  1. module.exports = { 
  2.     module: { 
  3.         rules: [ 
  4.             { 
  5.                 exclude: /\.(css|js|html|less|jpg|png|gif)$/, 
  6.                 loader: 'file-loader'
  7.                 options: { 
  8.                     name'[hash:10].[ext]'
  9.                 } 
  10.             } 
  11.         ] 
  12.     } 

四、Plugin

插件目的是解決loader無法實(shí)現(xiàn)的其他事,可用于執(zhí)行范圍更廣的任務(wù),為webpack帶來很大的靈活性。

4.1 HTML文件

為了簡化HTML文件的創(chuàng)建,方便為webpack包提供服務(wù),所以可以利用html-webpack-plugin插件。通過利用該插件可以自動(dòng)引入JS、CSS等文件,可以對HTM代碼進(jìn)行壓縮;此外,該插件還可以利用提供的HTML模板。

  1. module.exports = { 
  2.     plugins: [ 
  3.         // html-webpack-plugin插件,默認(rèn)會創(chuàng)建一個(gè)空的HTML,自動(dòng)引入打包輸出的所有資源(JS、CSS) 
  4.         new HtmlWebpackPlugin({ 
  5.             // 需要有結(jié)構(gòu)的HTML文件,可以通過配置template,復(fù)制該html文件,并自動(dòng)引入自動(dòng)引入打包輸出的所有資源(JS、CSS) 
  6.             template: './src/index.html'
  7.             // 壓縮html代碼 
  8.             minify: { 
  9.                 // 移除空格 
  10.                 collapseWhitespace: true
  11.                 // 移除注釋 
  12.                 removeComments: true
  13.             } 
  14.         }) 
  15.     ], 

4.2 CSS文件

對于CSS文件,利用插件主要需要處理三個(gè)方面:提取CSS文件、兼容性處理(配合postcss-loader)和對CSS文件進(jìn)行壓縮。

  • 提取CSS文件:mini-css-extract-plugin
  • 兼容性處理:post-preset-env
  • 壓縮:optimize-css-assets-webpack-plugin
  1. module.exports = { 
  2.     …… 
  3.     module: { 
  4.         rules: [ 
  5.             { 
  6.                 test: /\.css$/, 
  7.                 use: [ 
  8.                     // 'style-loader'
  9.                     MiniCssExtractPlugin.loader,// 用這個(gè)loader取代style-loader。作用:提取js中的css成單獨(dú)文件 
  10.                     'css-loader'
  11.                     { 
  12.                         loader: 'postcss-loader'
  13.                         options: { 
  14.                             ident: 'postcss'
  15.                             plugins: () => [ 
  16.                                 require('postcss-preset-env')() 
  17.                             ] 
  18.                         } 
  19.                     } 
  20.                 ] 
  21.             }, 
  22.         ] 
  23.     }, 
  24.     plugins: [ 
  25.         new MiniCssExtractPlugin({ 
  26.             // 對輸出的css文件進(jìn)行重命名 
  27.             filename: 'css/[name].css' 
  28.         }), 
  29.         // 壓縮css 
  30.         new OptimizeCssAssetsWebpackPlugin(), 
  31.     ] 

五、Mode

指示wenpack使用相應(yīng)模式進(jìn)行配置。

選項(xiàng) 描述
development 會將 DefinePlugin 中 process.env.NODE_ENV 的值設(shè)置為 development。啟用 NamedChunksPlugin 和 NamedModulesPlugin。
production 會將 DefinePlugin 中 process.env.NODE_ENV 的值設(shè)置為 production。啟用 FlagDependencyUsagePlugin, FlagIncludedChunksPlugin, ModuleConcatenationPlugin, NoEmitOnErrorsPlugin, OccurrenceOrderPlugin, SideEffectsFlagPlugin 和 TerserPlugin。
none 退出任何默認(rèn)優(yōu)化選項(xiàng)

 

本文轉(zhuǎn)載自微信公眾號「前端點(diǎn)線面」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系前端點(diǎn)線面公眾號。

 

責(zé)任編輯:武曉燕 來源: 前端點(diǎn)線面
相關(guān)推薦

2021-10-31 21:41:00

技術(shù)

2021-12-28 06:55:10

nginx配置命令

2022-01-23 23:35:04

vite項(xiàng)目webpack

2022-04-24 15:55:22

Go語言語言函數(shù)

2021-03-29 10:29:09

LinuxdockerLinux系統(tǒng)

2020-08-02 19:58:02

軟件工具科學(xué)

2020-11-26 18:18:21

微服務(wù)業(yè)務(wù)規(guī)模技術(shù)

2021-09-06 06:45:06

WebpackMindMasterEntry

2021-09-06 06:45:06

Webpack優(yōu)化MindMaster

2019-03-15 15:00:49

Webpack構(gòu)建速度前端

2019-03-26 10:02:16

WebpackJavascript前端

2021-07-08 07:30:13

Webpack 前端Tree shakin

2023-12-07 07:14:36

WebpackVite

2013-07-02 10:08:46

爛代碼代碼優(yōu)化代碼清理

2016-12-09 15:02:02

云計(jì)算

2021-12-16 07:49:12

元宇宙VR平行時(shí)空

2013-04-09 10:06:50

Facebook HoROMFacebook

2022-03-08 09:16:20

webpack前端開發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號