走進webpack(1)--環境拆分及模塊化

来源:https://www.cnblogs.com/zaking/archive/2018/03/25/8647377.html
-Advertisement-
Play Games

初級的文章和demo已經基本完成了,代碼也已經上傳到了我的github上,如果你對webpack的使用並不是十分瞭解,那麼建議你回頭看下走近系列,裡面包括了當前項目中使用頻繁的插件,loader的講解。以及基本的webpack配置,相關依賴等。如果你已經有了一定的webpack使用經驗。那麼你直接看 ...


  初級的文章和demo已經基本完成了,代碼也已經上傳到了我的github上,如果你對webpack的使用並不是十分瞭解,那麼建議你回頭看下走近系列,裡面包括了當前項目中使用頻繁的插件,loader的講解。以及基本的webpack配置,相關依賴等。如果你已經有了一定的webpack使用經驗。那麼你直接看這篇文章也是完全沒問題的。

  這一系列會著重講解webpack的進階使用方法,前面文章講解過的一些部分,就不會再去重覆的解釋。

  那麼,還是先交代一下環境以及目錄結構,這些你可以直接從github上獲取到:

  下麵是當前的環境配置版本:

  在實際的工作當中,我們會區分不同的環境來執行不同的webpack配置代碼,以實現不同環境的要求,當前的主要環境其實就兩個,一個開發環境,一個生產環境。開發環境更傾向於便捷的調試,開發的方便,比如熱載入等。而生產環境希望代碼的體積更小,http請求更少,頁面的載入速度更快。甚至有些時候兩個環境的要求是互斥的。所以才需要根據不同的環境來配置不同的代碼。

  廢話不多說,咱們直接進入正題吧。

 

  在前面的文章中,為了使靜態資源找到正確的路徑,我們設置了一個變數webpath,那麼如果要區分環境,變數的值肯定是不同的,那麼我們如何根據命令來使webpath獲得不同的值呢,其實很簡單:

  修改一下package.json中的build命令和dev命令,加上一個參數,然後我們在webpack.config.js中可以通過process.env來獲取到這個參數。這樣就可以區分不同的環境了。

"scripts": {
  "test": "echo \"Error: no test specified\" && exit 1",
  "build": "set type=build&webpack --mode production",
  "dev": "set type=dev&webpack-dev-server --mode development",
  "version": "webpack -v"
}

  那麼修改完package.json中的命令後,我們還需要修改一下webpack.config.js中webpath那段代碼:

/*根據參數的不同來區分不同的環境*/
if(process.env.type == "build"){
    var webpath={
/*這個地址目前是隨便寫的,只是為了區別於開發環境,真實上線的話要改成你上線的地址*/
        publicPath:"http://www.zaking.com/"
    }
}else{
    var webpath={
        publicPath:"http://192.168.199.124:9090/"
    }
}

  這樣就可以了,運行不同的命令來試試效果如何吧。這裡簡單說明一下,process.env是什麼,process是node的一個全局環境變數,process.env.type也就是你設置在scripts命令中的type值。更詳細的內容不在這裡多說,有強迫症的小伙伴可以去看看這裡:https://nodejs.org/dist/latest-v8.x/docs/api/process.html#process_process_env

  那麼環境拆分說完了,如何模塊化配置webpack呢?其實也很簡單,聽起來比較高逼格罷了。簡單說就是把通用變數放在一個單獨的js文件中,然後通過export暴露介面,require引入介面而已!比如你在使用vue中一定寫過很多這種東西,再簡單也要說一下滴。

  我們新建一個與webpack.config.js同級的文件夾,名字就叫做entry.js(入口)。然後我們在entry.js中寫入入口配置的代碼:

const entry ={};  
//聲明路徑屬性
entry.path={
    main:'./src/main.js'  
}
//導出該變數
module.exports = entry;

  然後在webpack.config.js中引入該模塊,並且修改下入口處的配置代碼:

/*在這裡引入entry文件的路徑*/
const entry =  require("./entry.js");
  /*入口文件*/
entry:entry.path

  這樣就實現了所謂的模塊化,當然這裡只是舉一個簡單的例子,複雜的配置項目可能會有邏輯複雜的模塊化配置。比如vue-cli那樣的,現在你再去看看vue-cli的代碼,應該也可以看懂一些了,只是它的功能更為複雜,模塊的關聯更強。那麼這篇文章就暫時寫到這裡。下一篇會帶大家一起看看如何打包第三方類庫等更貼近生活的實用技能。本篇文章的代碼也已經同步更新到github上了,以後隨著文章的更新會實時同步代碼,方便大家學習。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一.安裝版本簡介 MySQL是一個小巧玲瓏但功能強大的資料庫,目前十分流行。但是官網給出的安裝包有兩種格式,一個是msi格式,一個是zip格式的。很多人下了zip格式的解壓發現沒有setup.exe,面對一堆文件一頭霧水,不知如何安裝。 MySQL安裝文件分為兩種,一種是msi格式的,一種是zip格 ...
  • viewDidLoad:是視圖第一次載入到記憶體中後調用的,viewWillApear:則是在每次視圖顯示到屏幕上之前調用。 參考資料:《iOS編程指南》 ...
  • 引子用戶行為統計(User Behavior Statistics, UBS)一直是移動互聯網產品中必不可少的環節,也俗稱埋點。在保證移動端流量不會受較大影響的前提下,PM們總是希望埋點覆蓋面越廣越好。目前常規的做法是將埋點代碼封裝成工具類,但凡工程中需要埋點(如點擊事件、頁面跳轉)的地方都插入埋點 ...
  • android QMI機制 概論 android QMI機制 QMUX android QMI機制 Qcril初始化流程 android QMI機制 QCRIL消息發送 android QMI機制 底層消息發送 android QMI機制 Modem消息接收 android QMI機制 modem消 ...
  • 關於 微信公眾號:前端呼啦圈(Love-FED) 我的博客:勞卜的博客 知乎專欄:前端呼啦圈 前言 Hello,大家好,又與大家見面了,這次給大家分享下前端異常監控中需要瞭解的異常捕獲與上報機制的一些要點,同時包含了實戰性質的參考代碼和流程。 首先,我們為什麼要進行異常捕獲和上報呢? 正所謂百密一疏 ...
  • 調用方解決跨域的方法只有一種,那就是隱藏跨域。 何為隱藏跨域? 隱藏跨域的核心思路是通過反向代理隱藏跨域以欺騙瀏覽器 什麼是反向代理?反向代理是指通過中間伺服器使得訪問同一個功能變數名稱的兩個不同url最終會去往兩個不同的伺服器 一:反向代理 - Nginx配置 在之前的被調用方解決跨域中,訪問的請求是絕對 ...
  • Javascript作為前端開發必須掌握的一門語言,因為語言的靈活性,有些知識點看起來簡單,在真正遇到的時候,卻不一定會直接做出來,今天我們就一起來看看幾道題目吧 題目1 var val = 'smtg'; console.log(' Value is' + (val 'smtg') ? 'Some ...
  • 數組:使用單獨的變數名來存儲一系列的值。 數組元素:數組裡面的每一項 數組長度:數組裡面元素的個數 表示方法:數組名.length 數組下標(索引):數組元素在數組的位置,從0開始 如:var a = [12,45,7] 這個數組名為a 有三個元素,分別是12 45 7 ,45的位置是第1位。 還可 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...