webpack筆記

来源:https://www.cnblogs.com/jiangxiaoxi/archive/2020/03/02/12393332.html
-Advertisement-
Play Games

1、使用npm的預設配置初始化一個項目 nom init -y 2、安裝並使用當前目錄下的webpack,需要先卸載全局的webpack npm uninstall webpack web pack-cli -g 3、將webpack安裝在當前目錄下,好處是不同工程適配不同版本的webpack np ...


1、使用npm的預設配置初始化一個項目

nom init -y

 

2、安裝並使用當前目錄下的webpack,需要先卸載全局的webpack

npm uninstall webpack web pack-cli -g

 

3、將webpack安裝在當前目錄下,好處是不同工程適配不同版本的webpack

npm install webpack webpack-cli -D

 

4、安裝任意版本的webpack(例:4.16.5版本)

先查看webpack的各種版本信息:npm  info webpack

再安裝:npm install [email protected] web pack-cli -D

 

5、當前目錄下的webpack命令需要加npx

npx webpack

 

6、 配置文件webpack.config.json基本格式

module.exports={

entry: ‘./index.js’, //入口文件路徑 

output: {

filename: ‘bundle.js’, //輸出文件名

path: path.resolve(__direname, ‘bundle’) //輸出文件的絕對路徑

}

}

 

7、package.json中修改script欄位可變更打包命令,例:npm run build

"scripts": {

    "build": "webpack"

 },

 

8、打包非js文件時需要使用loader,配置文件中增加module欄位

module:{

rules:[{

test: /\.jpg|png|gif$/,   //遇到jpg或png或gif格式的文件時

use: {

loader: ‘file-loader’,   //使用file-loader

options: {

name: ‘[name].[ext]’,  //file-loader配置文件名及尾碼格式

}

}

}]

}

 

9、使用url-loader可以將文件轉換成base64的url字元串,這樣的好處是減少了一次http請求,

url-loader內嵌了file-loader,不需要重覆安裝file-loader

module:{

rules:[{

test: /\.jpg|png|gif$/,   //遇到jpg或png或gif格式的文件時

use: {

loader: ‘url-loader’,

options: {

name: ‘[name].[ext]’, //file-loader配置文件名及尾碼格式

outputPath: ‘images/’, //將這類生成的文件放在images文件夾下

limit: 204800 //小於200KB的文件使用url-loader,否則使用file-loader

}

}

}]

}

 

10、打包css、scss等樣式文件時的配置

module:{

rules[{

test: /\.css|scss$/,

use:[

’style-loader’,

{

loader:’css-loader’,

options: {

importLoaders: 2, //遇到新的css引入,從下往上重新走一遍loader的解析

modules: true //使用css的模塊模式,引入樣式只在當前js文件有效,不影響子文件

}

},

‘sass-loader’,

‘postcss-loader’

]

}]

}

 

11、htmlWepackPlugin會在打包結束後自動生成html文件,並將打包生成的JS文件

自動引入這個html中,也可以手動配置html模版

const htmlWebpackPlugin = require(‘html-webpack-plugin’) //引入html打包插件

plugins:[

new htmlWebpackPlugin({template: ’src/index.html’}). //使用src目錄下的index.html作為模版

]

 

12、cleanWebpackPlugin能夠再打包前清理打包輸出目錄。

const CleanWebpackPlugin = require(‘clean-webpack-plugin’);

Plugins:[

new CleanWebpackPlugin(‘dist’)      //dist為打包文件輸出目錄

]

 

13、source-map是源代碼和打包代碼的映射關係,cheap表示只精確到行且不映射loader等插件,module表示連同第三方插件和loader的映射也輸出

eval表示通過sourceURL關聯業務代碼模塊而不生成sourceMap文件,eval-source-map將生成的.map文件內容替換成嵌入sourceURL

devtool:’cheap-module-eval-source-map’ //開發環境最佳模式

 

14、加上—wathc命令後修改文件會自動打包(npm run webpack —watch),

但是這種方法只是將html頁面當作靜態界面訪問,無法實現http請求或是ajax請求(產生跨域問題)

 

15、webpack-dev-server能夠通過啟動一個http伺服器來完成代碼變化時自動打包,同時更多的配置還能夠

實現自動打開瀏覽器,無刷新修改頁面等功能

啟動伺服器命令:npm run web pack-dev-server

webpack.config.js中的基礎配置:

devServere:{

contentBase: ‘./build’ //打包文件生成目錄

open: true //啟動伺服器時自動打開一個伺服器

port: 8080 //啟動埠為8080

}

 

16、webpack作為API在node中使用時,可以通過npm安裝引入express伺服器模塊、webpack-dev-middleware打包模塊

來自己實現一個帶有自動打包功能的伺服器(webpack-dev-server就是以上兩個模塊組合編寫出來的)。

 

17、當修改文件後不想手動刷新頁面時需要使用熱模塊更新插件

webpack.config.js配置:

const webpakc = require(“webpack”)

devServe:{

contentBase: ”./dist”,

hot: “true”, //開啟熱更新

hotOnly: true //熱更新失效時是否自動刷新頁面

},

plugins:[ new webpack.HotMoudleReplacementPlugin() ]  //插件引入

 

18、ES6語法轉ES5語法使用babel的webpack.config.js配置

module:{

rules: [

test:  /\.js$/,

exclude: /node_modules/, //對該目錄下的文件不做處理

loader: “babel-loader”,

options: {

presets:[ [“@babel/preset-env”,{

useBuiltIns: ‘usage’  //只對引用到的ES6語法做轉化,設置此參數後不需要在文件中引入”@babel/polyfill”

}] ]

}

]

}

 

19、preset-env會污染全局變數,因此在寫類庫或組件庫時最好代替使用plugin-transform-runtime,

它會將babel以閉包的的方式引入,不會污染全局變數。若babel的配置項過多,

則可以將配置寫進文件名為.balbelrc的配置文件中

 

20、在導入模塊時,tree shaking能夠過濾掉模塊中不被引用部分,而只導入引用部分。

它只識別和優化ESmodule方式(import)的靜態引入,不支持優化CommonJS(require)方式的動態引入

tree shaking的webpack.config,js中的配置

optimization:{

usedExports: true   //開啟tree Shaking,便可只導入模塊中被引用部分

}

在package.json中的配置:

“sideEffects”:[ “*.js”] //使tree Shaking不對此類文件做處理


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

-Advertisement-
Play Games
更多相關文章
  • 什麼是Redis ? 簡單描述一下Redis的特點有哪些? Redis支持的數據類型 為什麼Redis需要把所有數據放到記憶體中? Redis是單線程的嗎? Redis持久化機制有哪些?區別是什麼?優缺點是什麼? Redis的緩存失效策略有哪幾種? 什麼是緩存命中率?提高緩存命中率的方法有哪些? Re ...
  • 1、jvm怎麼判斷哪些對象應該回收呢回答:引用計數演算法和可達性分析演算法 因為引用計數法的演算法是這樣的:在對象中添加一個引用計數器,每當一個地方引用它時,計數器就加一;當引用失效時,計數器值就減一;任何時刻計數器為零的對象就是不可能再被使用的。 但是這樣的演算法有個問題,是什麼呢? Object 1和O ...
  • 基礎篇 什麼是Redis及快速理解Redis的使用 Redis解決的問題及Redis的特性 Redis的應用場景及正確安裝與啟動 Redis配置、啟動、操作、關閉及版本選擇 字元串使用與內部實現原理 字典使用與內部實現原理 列表使用與內部實現原理 集合使用與內部實現原理 有序集合使用與內部實現原理 ...
  • 1、新建一個WinForm窗體,命名為Main: 2、在NuGet中安裝StackExchange.Redis。 3、添加一個類,命名為RedisHelper。 public static class RedisHelper { private static string Constr = ""; ...
  • 一、Redis下載 官網下載地址:http://redis.io/download GitHub下載地址:https://github.com/MSOpenTech/redis/tags 備註:現在的Redis官網沒有Windows版的下載鏈接了,只能到GitHub上下載,截止到此刻的最新版本還是3 ...
  • 遠程索引庫 將遠程索引庫添關聯到本地 pod repo 查看本地已關聯倉庫源 pod repo add 本地索引庫名稱 遠程索引庫倉庫地址 pod repo update 索引庫名稱 pod repo remove 本地索引庫名稱 執行命令 添加遠程索引庫`KTPodSpecs`克隆到本地 遠程庫 ...
  • 介面目前可用:抖音、塊手、火山、皮皮蝦、皮皮搞笑、最右、小紅書、美拍、今日頭條、微博、秒拍、小咖秀、晃咖、微視、全民小視頻、百度(好看)視頻、全民K歌、唱吧、音悅台、WIDE、嗶哩嗶哩、AcFun、梨視頻、趣多拍、網易雲音樂、陌陌、56網、芒果TV、CCTV、BBC、TikTok、Vigo、YouT ...
  • 從選伺服器,功能變數名稱,到配置伺服器,安裝環境,打包上傳,pm2進程守護一條龍。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...