成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

圖解Webpack之基礎(chǔ)篇

開發(fā) 前端
本節(jié)主要用于入門webpack,首先用一張利用MindMaster繪制思維導(dǎo)圖開篇來闡述本文的主要內(nèi)容,讀者可在此基礎(chǔ)上進(jìn)行擴(kuò)展自己的思維導(dǎo)圖。

[[421849]]

本節(jié)主要用于入門webpack,首先用一張利用MindMaster繪制思維導(dǎo)圖開篇來闡述本文的主要內(nèi)容,讀者可在此基礎(chǔ)上進(jìn)行擴(kuò)展自己的思維導(dǎo)圖。

一、Entry

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

1.1 單入口

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

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

1.2 多入口

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

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

輸入為對(duì)象,有幾個(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.     entry: () => new Promise((resolve) => resolve(['./src/index.js','./src/add.js'])) 

二、Output

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

2.1 名稱

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

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

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

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

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

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

2.2 路徑

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

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

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

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

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

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 樣式資源

對(duì)于css和less這樣的樣式資源,webpack不能直接進(jìn)行處理,所以需要經(jīng)過webpack翻譯后才可以使用。此外不同瀏覽器對(duì)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 圖片資源

對(duì)于圖片資源來說,主要可以分為html中圖片和非html中圖片。對(duì)于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.     } 

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

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

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

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

對(duì)于這個(gè)文件,只需要在js文件中直接引入即可 import '@babel/polyfill'; 這會(huì)將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 其它資源

對(duì)于不需要進(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文件

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

  1. module.exports = { 
  2.     plugins: [ 
  3.         // html-webpack-plugin插件,默認(rèn)會(huì)創(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文件

對(duì)于CSS文件,利用插件主要需要處理三個(gè)方面:提取CSS文件、兼容性處理(配合postcss-loader)和對(duì)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.             // 對(duì)輸出的css文件進(jìn)行重命名 
  27.             filename: 'css/[name].css' 
  28.         }), 
  29.         // 壓縮css 
  30.         new OptimizeCssAssetsWebpackPlugin(), 
  31.     ] 

五、Mode

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

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

 

本文轉(zhuǎn)載自微信公眾號(hào)「前端點(diǎn)線面」,作者前端點(diǎn)線面。轉(zhuǎn)載本文請(qǐng)聯(lián)系前端點(diǎn)線面公眾號(hào)。

 

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

2021-09-06 06:45:06

Webpack優(yōu)化MindMaster

2009-11-06 16:48:03

WCF簡(jiǎn)介

2010-05-27 17:41:09

2022-03-28 09:31:58

for循環(huán)語句

2011-01-18 10:00:59

Linux磁盤分區(qū)

2021-08-11 06:34:14

ZabbixDocker運(yùn)維

2021-03-02 12:36:49

MQKafkaRocketMQ

2019-10-12 15:06:02

MySQL數(shù)據(jù)庫命令

2024-02-02 10:38:06

虛擬文件系統(tǒng)VFS

2020-12-02 08:45:36

Go語言

2009-06-30 11:18:16

HTML表單JSP教程

2020-11-30 06:17:03

Go語言

2012-02-29 01:03:10

ubuntuLinux

2023-04-07 09:20:55

2020-11-26 06:40:24

Go語言基礎(chǔ)

2020-11-23 08:54:14

Go語言結(jié)構(gòu)體

2022-03-10 09:33:21

Java數(shù)組初始化

2011-07-27 12:19:40

交換機(jī)集線器

2021-04-30 09:46:08

虛擬化Virtio-Net云計(jì)算

2019-03-15 15:00:49

Webpack構(gòu)建速度前端
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 国产成人网 | 日韩免费视频一区二区 | 日本人做爰大片免费观看一老师 | 91毛片在线观看 | 青青草精品视频 | 天天操综合网 | 欧美日韩精品一区二区三区四区 | 国产在线一区二 | 九九热精品视频 | 国产一区二区精 | 国产91在线播放 | 国产成人一区二区三区 | 日韩视频 中文字幕 | 国产激情一区二区三区 | 69热视频在线观看 | 精品久久久久久 | 欧美精品国产一区二区 | 四虎影音| 国产精品久久 | 久久爱黑人激情av摘花 | 蜜桃久久 | 国产成人久久精品一区二区三区 | 欧美一级欧美三级在线观看 | 9191av| 欧美成人精品 | 欧美成人精品激情在线观看 | 56pao在线| 紧缚调教一区二区三区视频 | 亚洲精品免费视频 | 日韩av三区 | 日韩精品一区二区三区中文字幕 | 国产精品国产成人国产三级 | 人人爽人人草 | 中文字幕在线免费观看 | 日韩成人在线免费视频 | 久久精品—区二区三区 | 99久久精品免费看国产小宝寻花 | 99亚洲精品| 欧美在线一二三 | 成人免费视频网站在线观看 | 欧美1区2区 |