Webpack4 學習筆記六 多頁面配置和devtool

来源:https://www.cnblogs.com/qiqingfu/archive/2019/01/21/10301507.html
-Advertisement-
Play Games

webpack 多頁配置 webpack可以配置單頁應用, 也可以配置多頁應用。 區別在於, 單頁應用entry入口只有一個, 而多頁應用入口有多個 webpack配置: 以上代碼, HtmlWebpackPlugin 實例話了兩次, 每次都會生成一個html,所謂的多頁。並且選項中的, chunk ...


webpack 多頁配置

webpack可以配置單頁應用, 也可以配置多頁應用。

區別在於, 單頁應用entry入口只有一個, 而多頁應用入口有多個

webpack配置:

const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')

module.exports = {
  mode: "development",
  entry: {
    home: './src/home.index',
    about: './src/about.js'
  },
  output: {
    // 多個入口的文件不能打包的一個文件中, 應該用name區別。這樣就會輸出 home.js和about.js
    filename: '[name].js',
    path: path.resolve(__dirname, 'dist')
  },
  plugins: [
    new HtmlWebpackPlugin({
      title: 'page home',
      template: './index.html', // 模版文件
      filename: 'index.html',
      chunks: ['home']
    }),
    new HtmlWebpackPlugin({
      title: 'page about',
      template: './index.html', // 模版文件
      filename: 'index.html',
      chunks: ['about']
    })
  ]
}

以上代碼, HtmlWebpackPlugin 實例話了兩次, 每次都會生成一個html,所謂的多頁。並且選項中的, chunks的設置主要讓每個index.html分別引用它自己的js文件。

webpack devtool

此選項控制是否生成,以及如何生成 source map。

source-map

源碼映射, 會單獨生成一個sourcemap文件, 出錯了,會標識當前報錯的列和行, 大而全,並且是相互獨立的。
source-map 是所有選項中最慢和最高質量的選擇,但這對於生產建設來說是很好的

eval-source-map

不會產生單獨的文件, 但是可以顯示列和行。和source-map的主要區別是不會產生文件

cheap-module-source-map

簡化後的 source-map, 不會產生列, 但是是一個單獨的map文件,產生後你可以保留起來,用於調試

cheap-module-eval-source-map

不會生成map文件,不會顯示列,可以定位到錯誤的行

webpack配置

module.exports = {
  devtool: "source-map"
}

總結:

開發環境推薦使用:

  • eval :每個模塊使用eval()和//@ sourceURL執行。這是非常快。主要缺點是,它沒有正確顯示行號,因為它被映射到轉換代碼而不是原始代碼(沒有來自載入器的源映射)。

  • eval-source-map:每個模塊使用eval()執行,而SourceMap作為DataUrl添加到eval()中。最初它是緩慢的,但是它提供快速的重建速度和產生真實的文件。行號被正確映射,因為它被映射到原始代碼。它產生了最優質的開發資源。

  • cheap-eval-source-map:與eval-source-map類似,每個模塊都使用eval()執行。它沒有列映射,它只映射行號。它忽略了來自載入器的源代碼,並且只顯示與eval devtool相似的經過轉換的代碼。

  • cheap-module-eval-source-map:類似於cheap-eval-source-map,在本例中,來自載入器的源映射被處理以獲得更好的結果。然而,載入器源映射被簡化為每一行的單個映射。

生產環境推薦使用

  • (none) :(省略devtool選項)-不觸發SourceMap。這是一個很好的選擇。

  • source-map:一個完整的SourceMap是作為一個單獨的文件。它為bundle 添加了引用註釋,因此開發工具知道在哪裡找到它。

  • hidden-source-map:與source-map相同,但不向bundle 添加引用註釋。如果您只希望SourceMaps從錯誤報告中映射錯誤堆棧跟蹤,但不想為瀏覽器開發工具暴露您的SourceMap,可以使用此選項。

參考文章: webpack之devtool


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

-Advertisement-
Play Games
更多相關文章
  • ...
  • 起因: 最近做的APP中有一個新功能:已知用戶微信號,可點擊直接跳轉到當前用戶微信聊天視窗頁面。 當時第一想法是使用無障礙來做,並且覺得應該不難,只是邏輯有點複雜。沒想到最終踩了好多坑,特地把踩過的坑記錄下來。 實現邏輯: 在APP中點擊按鈕→跳轉到微信界面→模擬點擊微信搜索按鈕→在微信搜索頁面輸入 ...
  • [TOC] 1. Intent啟動器 1.1. Intent的用途 1. 啟動Activity :希望返回結果 2. 啟動服務 啟動一個不適用用戶界面而在後臺執行操作的組件 :下載文件等,可攜帶任何必要的數據 : 使用客戶端 伺服器介面,從其他組件綁定到此服務 3. 傳遞廣播 廣播是任何應用均可接收 ...
  • [TOC] 1.載入器特征 用於每個 和 支持非同步載入數據。 監控其數據源併在內容變化時傳遞新結果。 2. Loader API 3. 在應用中使用Loader 主要步驟 1. 或 2. 的實例 3. 一個 ,用於載入由 支持的數據。您也可以實現自己的 或 子類,從其他源中載入數據。 4. 一個 實 ...
  • [TOC] 1. Fragment是什麼 fragment表示 Activity 中的行為或用戶界面部分。可以將多個片段組合在一個 Activity 中來構建多窗格 UI fragment是activity的模塊化組成部分 fragemnt性質: 有自己的生命周期 可以接收輸入事件,並且可以在act ...
  • 功能描述:彈出鍵盤,右邊有最大化按鈕,沒有最大化的時候最大行數為3,預設1行,隨著文字輸入增加自動增加高度,到達3行時不會在增加,點擊最大化輸入框,行數無限制,輸入框下方圖片點擊刪除 此處為了簡便,鍵盤監聽用了一個庫,如果自己寫也簡單,直接 addOnGlobalLayoutListener 便可 ...
  • 手機端與平臺之間的視頻直播功能,主要通過集成多種開源視頻框架以及採購第三方視頻直播伺服器產品來實現預定業務需求。視頻直播對話功能的實現,主要經歷了三個階段:利用開源視頻框架實現視頻直播、採購第三方視頻伺服器實現視頻直播、系統平臺集成開源框架實現視頻互播。 圖1.視頻互播邏輯框架 1 利用開源視頻框架 ...
  • 一,效果圖。 二,代碼。 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>CSS Table表格</title> <style> table { border-collapse: collapse; width: 100%; } ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...