摘要:簡介模式是新增的配置,用來指定使用對應(yīng)模式的內(nèi)置優(yōu)化它有三個可選模式默認為。源碼地址選項描述通過插件將的值設(shè)為。啟用和通過插件將的值設(shè)為。使用默認的優(yōu)化項。注意上面說的并不是的運行環(huán)境變量,它其實是通過插件設(shè)置的一個全局變量。
簡介
? mode(模式)是webpack4.0.0新增的配置,用來指定webpack使用對應(yīng)模式的內(nèi)置優(yōu)化;它有三個可選模式:production、development、none;默認為production。
源碼地址
選項 | 描述 |
---|---|
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 | 通過DefinePlugin插件將 process.env.NODE_ENV 的值設(shè)為 node。使用默認的優(yōu)化項。 |
下面通過一段代碼分別演示一個每一個模式打包輸出的文件內(nèi)容:
第一步:編寫入口文件和依賴代碼
// webpack@4.32.2系列教程/demo02-mode/src/role.js export default class Role { constructor(name, skill) { this.name = name; this.skill = skill; } }
// webpack@4.32.2系列教程/demo02-mode/src/index.js import Role from "./role" const role = new Role("喬峰", "降龍十八掌"); console.log(role); console.log("process.env.NODE_ENV: ", process.env.NODE_ENV);
第二步:編寫webpack配置 & 啟動webpack
// webpack@4.32.2系列教程/demo02-mode/scripts/build.js const webpack = require("webpack"); // 創(chuàng)建編譯器對象 const compiler = webpack({ // mode模式:webpack4.0.0新增配置,用來指定webpack使用相應(yīng)模式的內(nèi)置優(yōu)化。 // mode: "development" // 會將 process.env.NODE_ENV 的值設(shè)為 development。啟用 NamedChunksPlugin 和 NamedModulesPlugin。 // mode: "production" // 會將 process.env.NODE_ENV 的值設(shè)為 production。啟用 FlagDependencyUsagePlugin, FlagIncludedChunksPlugin, ModuleConcatenationPlugin, NoEmitOnErrorsPlugin, OccurrenceOrderPlugin, SideEffectsFlagPlugin 和 UglifyJsPlugin. mode: "none" // 使用默認優(yōu)化項 }); // 啟動webpack compiler.run((err, stats) => { if (err) { console.error(err); return; } // 輸出編譯成功信息 console.log(stats.toString({ colors: true })); });
第三步:cd到demo02-mode文件夾下,運行node scripts/build.js
mode: none 打包輸出的main.js文件內(nèi)容
mode:development 打包輸出的main.js文件內(nèi)容
mode:production 打包輸出的main.js文件內(nèi)容
小結(jié): 可以看到每一種模式,打包后輸出的代碼都不一樣,我們平時開發(fā)使用development模式,當(dāng)代碼需要發(fā)布上線時使用production模式。
注意: 上面說的process.env.NODE_ENV并不是Node.js的process.env.NODE_ENV運行環(huán)境變量,它其實是通過DefinePlugin插件設(shè)置的一個webpack全局變量。
配置? mode其實可以理解為webpack4.0.0 提供一個語法糖,它的三個可選項,其實就是三套不同的webpack默認配置而已,以下是每一種模式對應(yīng)的webpack配置:
mode: development mode: production mode: none文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/104243.html
摘要:簡介選項用于控制是否需要生成,以及如何生成。表示把每一個模塊文件都轉(zhuǎn)換為字符串,并且在每一個模塊代碼的尾部添加文件名,并使用執(zhí)行。通過來處理已有的。優(yōu)點是不需要建立和部署內(nèi)網(wǎng)的服務(wù)器,缺點是無法直接線上源碼。 簡介 ? devtool選項用于控制是否需要生成source map,以及如何生成source map。源碼地址 什么是source map? ? source ma...
摘要:核心概念是一個前端資源模塊打包工具,它可以根據(jù)模塊的依賴關(guān)系進行打包輸出成瀏覽器能夠識別的靜態(tài)資源,可以把多個文件打包成一個,減少請求。源碼地址零配置啟動從開始,可以零配置啟動,命令被遷移到一個單獨的包上,的功能變得更加豐富強大。 核心概念 ? webpack是一個前端資源模塊打包工具,它可以根據(jù)模塊的依賴關(guān)系進行打包輸出成瀏覽器能夠識別的靜態(tài)資源,可以把多個文件打包成一...
摘要:按屏幕往后移動半頁。按移動到光標(biāo)所在行的行首按光標(biāo)跳到下個字的開頭按光標(biāo)跳到下個字的字尾按光標(biāo)回到上個字的開頭按光標(biāo)移到該行的第個位置,如。例如,,表示移動光標(biāo)至文章的第行行首。 01:查找和替換 例1:要找about字符串 /about 在命令行輸入/后接要查找的字符串,下一個匹配按n(ext),上一個是N?about 在當(dāng)前位置找,n跳到前一個匹配/about$ 匹配行尾的a...
showImg(http://img3.douban.com/lpic/s8958650.jpg); 0x00 javascript組成 ECMAScript(-265)核心語言部分 DOM文檔對象模型(DOM1、2、3) BOM瀏覽器對象模型(提供與瀏覽器交互的接口和方法) 0x01 async 異步加載 執(zhí)行順序不定 charset defer 延遲加載,立即下載腳本但不執(zhí)行 src ...
閱讀 1308·2023-04-26 01:03
閱讀 1942·2021-11-23 09:51
閱讀 3311·2021-11-22 15:24
閱讀 2672·2021-09-22 15:18
閱讀 1018·2019-08-30 15:55
閱讀 3487·2019-08-30 15:54
閱讀 2257·2019-08-30 15:53
閱讀 2398·2019-08-30 15:44