Next+React項(xiàng)目啟動(dòng)慢刷新慢的解決方法小結(jié)
上班的時(shí)候遇到公司Next+React項(xiàng)目啟動(dòng)很慢,更改樣式也加載半天,十分影響開(kāi)發(fā)效率,在前輩的改動(dòng)下,運(yùn)行速度加快了很多,特此學(xué)習(xí)記錄。
在 next.config.js 中編寫(xiě)如下代碼:
/** @type {import('next').NextConfig} */
const WindiCSSWebpackPlugin = require('windicss-webpack-plugin');
module.exports = {
reactStrictMode: false,
env: {
NEXT_PUBLIC_APP_ENV: process.env.NEXT_PUBLIC_APP_ENV,
},
images: {
loader: 'imgix',
unoptimized: true,
path: 'http://uat.onetouch-tech.com/',
},
webpack(config, { dev }) {
// 如果是開(kāi)發(fā)模式 (dev),處理 config.entry
if (dev) {
// 確保 config.entry 是一個(gè)數(shù)組
if (Array.isArray(config.entry)) {
config.entry = config.entry.filter(entry => !entry.includes('webpack-dev-server'));
} else if (typeof config.entry === 'object') {
// 如果 config.entry 是對(duì)象形式,逐個(gè)遍歷它的條目
Object.keys(config.entry).forEach(key => {
config.entry[key] = config.entry[key].filter(entry => !entry.includes('webpack-dev-server'));
});
}
config.plugins.push(new WindiCSSWebpackPlugin());
}
// 返回修改后的 Webpack 配置
return config;
},
};
if (dev):這部分配置只在開(kāi)發(fā)模式下執(zhí)行,確保只有在開(kāi)發(fā)模式下才會(huì)進(jìn)行相應(yīng)的處理。
config.entry 處理:
- 這一段的代碼過(guò)濾掉了 Webpack 內(nèi)部的 webpack-dev-server 條目。webpack-dev-server 是開(kāi)發(fā)環(huán)境下的一個(gè)內(nèi)置服務(wù),用于熱模塊重載(HMR)。但是,在 Next.js 中,熱更新本身是通過(guò) Next.js 自己的開(kāi)發(fā)服務(wù)器來(lái)處理的,所以刪除這些條目可以減少冗余配置,減少 Webpack 的開(kāi)銷(xiāo)。
config.plugins.push(new WindiCSSWebpackPlugin()):
- 這個(gè)插件是 WindiCSS 的 Webpack 插件。WindiCSS 是一個(gè)類(lèi)似于 TailwindCSS 的工具,但它通過(guò)按需生成 CSS 來(lái)減少樣式文件的大小,從而提升性能。這個(gè)插件會(huì)在構(gòu)建過(guò)程中自動(dòng)生成并優(yōu)化使用到的 CSS 類(lèi),避免了不必要的樣式文件的生成,從而減小了最終包的大小。
一、為什么移除開(kāi)發(fā)模式下的 webpack-dev-server,項(xiàng)目變快?
webpack-dev-server 是 Webpack 提供的一個(gè)開(kāi)發(fā)服務(wù)器,它通常用來(lái)提供熱模塊替換(HMR)和實(shí)時(shí)更新功能。在默認(rèn)情況下,webpack-dev-server 會(huì)監(jiān)視你的文件系統(tǒng),當(dāng)檢測(cè)到文件發(fā)生變化時(shí),立即重新構(gòu)建并更新頁(yè)面。
如果你移除了 webpack-dev-server,啟用了 Next.js 自帶的 HMR(熱模塊替換)機(jī)制,它通常比 Webpack 默認(rèn)的 webpack-dev-server 實(shí)現(xiàn)更加高效,尤其是在大量代碼變更時(shí),Next.js 會(huì)盡量只更新實(shí)際變更的部分,而不是重新構(gòu)建整個(gè)應(yīng)用。
過(guò)濾 webpack-dev-server 相關(guān)入口
!entry.includes('webpack-dev-server')作用:排除所有包含 webpack-dev-server 字符串的入口文件
原因:在 Next.js 開(kāi)發(fā)模式下,默認(rèn)可能包含以下冗余入
效果:減少約 15-30% 的初始構(gòu)建文件數(shù)量
二、webpack-dev-server 相關(guān)入口文件是什么?
webpack-dev-server 相關(guān)入口文件 是指在 Webpack 配置中,由 webpack-dev-server 自動(dòng)注入或顯式引入的、用于支持開(kāi)發(fā)服務(wù)器功能的文件。這些文件通常是客戶(hù)端腳本,用于實(shí)現(xiàn) 熱更新(HMR) 和 實(shí)時(shí)重載(Live Reload) 等功能。
三、webpack-dev-server 相關(guān)入口文件的典型示例
1. 客戶(hù)端腳本
node_modules/webpack-dev-server/client/index.js
作用:
建立 WebSocket 連接,與開(kāi)發(fā)服務(wù)器通信
接收服務(wù)器推送的更新消息(如文件變更)
觸發(fā)瀏覽器的熱更新或頁(yè)面重載
2. 熱更新運(yùn)行時(shí)
node_modules/webpack/hot/dev-server.js
作用:
實(shí)現(xiàn)模塊熱替換(HMR)的核心邏輯
管理模塊的加載和替換
處理更新失敗時(shí)的回退邏輯
3. 代理配置相關(guān)文件
node_modules/webpack-dev-server/client/socket.js
作用:
處理 WebSocket 連接的建立和維護(hù)
支持開(kāi)發(fā)服務(wù)器的代理功能
四、為什么這些文件會(huì)被注入
webpack-dev-server 在啟動(dòng)時(shí),會(huì)自動(dòng)將這些文件添加到 Webpack 的入口配置中
目的是確保開(kāi)發(fā)服務(wù)器功能(如 HMR)能夠正常工作
到此這篇關(guān)于Next+React項(xiàng)目啟動(dòng)慢刷新慢的解決方法小結(jié)的文章就介紹到這了,更多相關(guān)Next+React項(xiàng)目啟動(dòng)慢刷新慢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
React?UI組件庫(kù)之快速實(shí)現(xiàn)antd的按需引入和自定義主題
react入門(mén)學(xué)習(xí)告一段路,下面這篇文章主要給大家介紹了關(guān)于React?UI組件庫(kù)之快速實(shí)現(xiàn)antd的按需引入和自定義主題的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
Redux DevTools不能顯示數(shù)據(jù)問(wèn)題
這篇文章主要介紹了Redux DevTools不能顯示數(shù)據(jù)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
React Native驗(yàn)證碼倒計(jì)時(shí)工具類(lèi)分享
這篇文章主要為大家分享了React Native驗(yàn)證碼倒計(jì)時(shí)工具類(lèi),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
解決react-connect中使用forwardRef遇到的問(wèn)題
這篇文章主要介紹了解決react-connect中使用forwardRef遇到的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
使用?React?Hooks?重構(gòu)類(lèi)組件的示例詳解
這篇文章主要介紹了如何使用?React?Hooks?重構(gòu)類(lèi)組件,本文就來(lái)通過(guò)一些常見(jiàn)示例看看如何使用 React Hooks 來(lái)重構(gòu)類(lèi)組件,需要的朋友可以參考下2022-07-07
React中jquery引用的實(shí)現(xiàn)方法
這篇文章主要介紹了React中jquery引用的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09
react后臺(tái)系統(tǒng)最佳實(shí)踐示例詳解
這篇文章主要為大家介紹了react后臺(tái)系統(tǒng)最佳實(shí)踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01

