webpack 如何區分開發環境和生產環境

第一種方法:

方法出處:命令行接口(CLI) | webpack 中文文檔

1.利用webpack.config.js 返回的是個函數,利用函數的參數,來區分環境

? 具體步驟

? ? ?1) package.json文件:在npm scripts 命令后面追加?--node-env production/development

 ?"build": "webpack --config webpack.config.js --node-env development"

? ?2)webpack.config.js 是個函數形式,可以看到函數有兩個參數,把參數都打印出來看看,可以看到process.nodeEnv 既是上述 --node-env 后面設置的值

const path = require('path');
module.exports = (env,process)=>{console.log('Production: ', env); console.log('process',process);console.log(process.nodeEnv);return {entry: './src/index.js',output: {path: path.resolve(__dirname, 'dist'),filename: 'webpack-numbers-test.js',library: {type:'umd',name:"webpackNumbersTest"},globalObject: 'this',clean:true},externals:{commonjs: 'lodash',commonjs2: 'lodash',amd: 'lodash',root: '_',}
};
}

第二種方法:

? ? 1. 安裝 cross-env

npm install cross-env -D

? 2. 在package.json npm scripts 前面追加?cross-env NODE_ENV=production/development

 "build": "cross-env NODE_ENV=production webpack --config webpack.config.js",

3.即可在webpack.config.js 中訪問?process.env.NODE_ENV

第三種方法

將公共的,生產和開發的不同抽離出來,利用webpack-merge 進行合并?

方法出處:生產環境 | webpack 中文文檔

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/85259.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/85259.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/85259.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

React組件通信——context(提供者/消費者)

Context 是 React 提供的一種組件間通信方式,主要用于解決跨層級組件 props 傳遞的問題。它允許數據在組件樹中"跨級"傳遞,無需顯式地通過每一層 props 向下傳遞。 一、Context 核心概念 1. 基本組成 React.createContext:創建 C…

“微信短劇小程序開發指南:從架構設計到上線“

1. 引言:短劇市場的機遇與挑戰 近年來,短視頻和微短劇市場呈現爆發式增長,用戶碎片化娛樂需求激增。短劇小程序憑借輕量化、社交傳播快、變現能力強等特點,成為內容創業的新風口。然而,開發一個穩定、流暢且具備商業價…

RPC與RESTful對比:兩種API設計風格的核心差異與實踐選擇

# RPC與RESTful對比:兩種API設計風格的核心差異與實踐選擇 ## 一、架構哲學與設計目標差異 1. **RPC(Remote Procedure Call)** - **核心思想**:將遠程服務調用偽裝成本地方法調用(方法導向) - 典型行為…

【pytest進階】pytest之鉤子函數

什么是 hook (鉤子)函數 經常會聽到鉤子函數(hook function)這個概念,最近在看目標檢測開源框架mmdetection,里面也出現大量Hook的編程方式,那到底什么是hook?hook的作用是什么? what is hook ?鉤子hook,顧名思義,可以理解是一個掛鉤,作用是有需要的時候掛一個東西…

深度學習計算——動手學深度學習5

環境:PyCharm python3.8 1. 層和塊 塊(block)可以描述 單個層、由多個層組成的組件或整個模型本身。 使用塊進行抽象的好處: 可將塊組合成更大的組件(這一過程通常是遞歸) 如 圖5.1.1所示。通過定義代碼來按需生成任意復雜度…

NodeJS的fs模塊的readFile和createReadStream區別以及常見方法

Node.js 本身沒有像 Java 那樣嚴格區分字符流和字節流,區別主要靠編碼(encoding)來控制數據是以 Buffer(二進制字節)形式還是字符串(字符)形式處理。 詳細解釋: 方面JavaNode.js字節…

基于二進制XOR運算的機器人運動軌跡與對稱圖像自動生成算法

原創:項道德(daode3056,daode1212) 新的算法出現,往往能給某些行業與產業帶來革命與突破。為探索機器人運動軌跡與對稱圖像自動生成算法,本人已經通過18種算法的測試,最終,以二進制的XOR運算為…

Spring AI 項目實戰(七):Spring Boot + Spring AI Tools + DeepSeek 智能工具平臺(附完整源碼)

系列文章 序號文章名稱1Spring AI 項目實戰(一):Spring AI 核心模塊入門2Spring AI 項目實戰(二):Spring Boot + AI + DeepSeek 深度實戰(附完整源碼)3Spring AI 項目實戰(三):Spring Boot + AI + DeepSeek 打造智能客服系統(附完整源碼)4Spring AI 項目實戰(四…

spring-webmvc @RequestHeader 典型用法

典型用法 基礎用法:獲取指定請求頭值 GetMapping("/info") public String getInfo(RequestHeader("User-Agent") String userAgent) {return "User-Agent: " userAgent; }如果請求中包含 User-Agent 請求頭,則其值將被…

Ubuntu:20.04中安裝docker

是的,您列出的命令是完整的安裝步驟,但為了確保100%可靠性和處理可能的問題,我建議進行以下優化和補充: 完整優化的安裝腳本(包含錯誤處理和驗證) #!/bin/bash# 1. 徹底清理舊版本和配置 sudo apt remove…

大數據實時風控引擎:Spark Streaming、Kafka、Flink與Doris的融合實踐

大數據實時風控引擎:Spark Streaming、Kafka、Flink與Doris的融合實踐 在數字金融、電商交易與在線服務的核心戰場,風險控制能力已成為業務的生命線。傳統批量風控模式在應對瞬息萬變的欺詐攻擊、信用風險時捉襟見肘。本文將深入探討如何利用**Spark St…

【創龍瑞芯微 RK3576 全國產 ARM 八核 2.2GHz 工業開發板-硬件說明書】

前 言 本文主要介紹TL3576-EVM評估板硬件接口資源以及設計注意事項等內容。 RK3576J/RK3576處理器的IO電平標準一般為1.8V、3.3V,上拉電源一般不超過3.3V或1.8V,當外接信號電平與IO電平不匹配時,中間需增加電平轉換芯片或信號隔離芯片。按鍵或接口需考慮ESD設計,ESD器件…

一文吃透ADB,從入門到精通

目錄 一、ADB 簡介1.1 什么是 ADB1.2 ADB 的工作原理1.3 ADB 的安裝與環境配置 二、ADB 基礎命令2.1 設備連接相關命令2.2 應用管理命令2.3 文件傳輸命令 三、ADB 高級命令3.1 ADB Shell 深入探究3.2 日志查看與分析3.3 設備信息獲取3.4 屏幕操作與錄制 四、ADB 常見問題與解決…

PostgreSQL高可用架構設計與實踐指南

# PostgreSQL高可用架構設計與實踐指南 ## 一、高可用性核心訴求 PostgreSQL作為企業級關系型數據庫,高可用設計需要滿足以下關鍵指標: - 故障恢復時間(RTO):秒級到分鐘級自動切換能力 - 數據損失容忍度&#xff0…

今天我想清楚了

首先說一聲抱歉,很多天沒有更新了,因為在我這里,我的內心感到迷茫,從來沒有這樣過,不知道為什么自己一直要做的事,進度太慢了,因為我的人生是空虛的,我感覺我做的不夠好,…

代碼隨想錄day3鏈表1

new關鍵字 1.new是一個關鍵字,用于開辟空間,開辟的空間在堆上,而一般聲明的變量存放在棧上; 2.new得到的是一段空間的首地址。所以一般需要用指針來存放這段地址 new int(10);//返回new出來這塊內存的地址int *pnew int(10);//…

taro小程序如何實現新用戶引導功能?

一、需求背景 1、需要實現小程序新功能引導 2、不使用第三方庫(第三方組件試了幾個,都是各種兼容性問題,放棄) 二、實現步驟 1、寫一個公共的guide組件,代碼如下 components/Guide/index.tsx文件 import React, { …

鍵盤動作可視化技術淺析:如何做到低延遲顯示

在做屏幕錄制或者操作演示的時候,你是否遇到過這樣的問題:觀眾看不清你按了哪個鍵、點了哪里?這是能完美解決這個問題的小工具Keyviz。它可以把你的鍵盤輸入和鼠標點擊實時顯示在屏幕上,清晰直觀,特別適合教學、錄屏、…

Prufer序列 學習筆記

文章目錄 P r u f e r Prufer Prufer 序列對樹建立 P r u f e r Prufer Prufer 序列對 P r u f e r Prufer Prufer 序列重建樹 應用Cayley 公式[HNOI2004] 樹的計數「雅禮集訓 2017 Day8」共[THUPC 2018] 城市地鐵規劃CF156D Clues[ARC106F] Figures P r u f e r Prufer Pruf…

高性能場景使用Protocol Buffers/Apache Avro進行序列化怎么實現呢

我們以Protocol Buffers(Protobuf)和Apache Avro為例,分別展示高性能序列化的實現方式。 由于兩者都需要定義Schema,然后生成代碼,因此步驟包括: 1. 定義Schema文件 2. 使用工具生成Java類 3. 在代碼中…