react項目做的h5頁面加載緩慢優化(3s優化到0.6s)

打包到生產環境時去掉SOURCEMAP
禁用生成 Source Map 是一種權衡,可以根據項目的實際需求和優化目標來決定是否禁用。如果您對調試需求不是特別強烈,可以考慮在生產構建中禁用 Source Map 以獲取更好的性能。但如果需要保留調試能力,可以在生產構建中保留生成 Source Map
“buildProd”: “BUILD_ENV=prod GENERATE_SOURCEMAP=false react-app-rewired build”
配置webpack進行相關優化

  1. 代碼壓縮,去掉log日志
config.optimization.minimizer.push(new TerserPlugin({terserOptions: {compress: {drop_console: true,},output: {comments: false,},},}));
  1. 根據git版本生成輸出目錄
const gitVersion = child_process.execSync('git rev-parse --short HEAD').toString().trim();const prePath = `${gitVersion}`const staticPath = `prePath`// 更改輸出目錄config.output.path = path.resolve(__dirname, `build/`);// js chunk assetconfig.output.filename = `${prePath}/js/[name].[contenthash:8].js`;config.output.chunkFilename = `${prePath}/js/[name].[contenthash:8].chunk.js`;config.output.assetModuleFilename = `${prePath}/media/[name].[hash][ext]`;
  1. CDN加速,開發環境和生產環境分開
if (process.env.BUILD_ENV == "prod") {// 更改公共路徑config.output.publicPath = `https://didbrowser-prod.oss-cn-chengdu.aliyuncs.com/`}if (process.env.BUILD_ENV == "dev") {config.output.publicPath = `https://didbrowser-dev.oss-cn-chengdu.aliyuncs.com/`}
  1. 對第三方插件大模塊chunks 進行代碼分割
config.optimization = {...config.optimization,splitChunks: {cacheGroups: {echarts: {test: /[\\/]node_modules[\\/]echarts[\\/]/, // 匹配 ECharts 模塊name: 'echarts', // 生成的文件名chunks: 'all', // 對所有的 chunks 進行代碼分割}},},};
  1. 更改 CSS 的輸出路徑
const miniCssExtractPlugin = config.plugins.find(plugin => plugin instanceof MiniCssExtractPlugin);if (miniCssExtractPlugin) {miniCssExtractPlugin.options.filename = `${prePath}/css/[name].[contenthash:8].css`;miniCssExtractPlugin.options.chunkFilename = `${prePath}/css/[name].[contenthash:8].chunk.css`;}

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

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

相關文章

【量化課程】08_1.機器學習量化策略基礎實戰

文章目錄 1. 常用機器學習模型1.1 回歸模型1.2 分類模型1.2.1 SVC介紹1.2.2 SVC在量化策略中的應用 2. 機器學習量化策略實現的基本步驟3. 策略實現 1. 常用機器學習模型 1.1 回歸模型 線性回歸多層感知器回歸自適應提升樹回歸隨機森林回歸 1.2 分類模型 線性分類支持向量機…

Android布局【FrameLayout】

文章目錄 常見屬性說明項目結構主要代碼 常見屬性 android:foreground:設置前景android:foregroundGravity:設置前景位置 說明 FrameLayout的其他屬性與前面學的差不多,只不過需要特別注意上面兩個即可 項目結構 主要代碼 activity_main…

【leetcode】第2章 鏈表

203. 移除鏈表元素 方法:添加一個虛擬節點,這不用考慮頭節點刪除情況 public ListNode removeElements(ListNode head, int val) {// 虛擬節點,指向頭節點ListNode dummy new ListNode(0);dummy.next head;ListNode p dummy;// 找到被刪…

數據結構:樹狀數組

老規矩,推薦一篇原理講解清晰的博客!(樹狀數組(詳細分析應用),看不懂打死我!_樹形數組_鮮果維他命的博客-CSDN博客) 相對于線段樹,樹狀數組的優點就是代碼簡潔,容易修改。單缺點就是優點問題只…

計算機視覺中的特征檢測和描述

一、說明 這篇文章是關于計算機視覺中特征檢測和描述概念的簡要理解。在其中,我們探討了它們的定義、常用技術、簡單的 python 實現和一些限制。 二、什么是特征檢測和描述? 特征檢測和描述是計算機視覺中的基本概念,在圖像識別、對象跟蹤和圖…

Beats:使用 Filebeat 將 golang 應用程序記錄到 Elasticsearch - 8.x

毫無疑問,日志記錄是任何應用程序最重要的方面之一。 當事情出錯時(而且確實會出錯),我們需要知道發生了什么。 為了實現這一目標,我們可以設置 Filebeat 從我們的 golang 應用程序收集日志,然后將它們發送…

Maven教程_編程入門自學教程_菜鳥教程-免費教程分享

教程簡介 Maven 是一款基于 Java 平臺的項目管理和整合工具,它將項目的開發和管理過程抽象成一個項目對象模型(POM)。開發人員只需要做一些簡單的配置,Maven 就可以自動完成項目的編譯、測試、打包、發布以及部署等工作。Maven 是…

微信小程序備案流程

微信小程序備案流程 📔 千尋簡筆記介紹 千尋簡筆記已開源,Gitee與GitHub搜索chihiro-notes,包含筆記源文件.md,以及PDF版本方便閱讀,且是用了精美主題,閱讀體驗更佳,如果文章對你有幫助請幫我…

二、異常日志

二、異常日志 (一)、錯誤碼 錯誤碼的制定原則:快速溯源、溝通標準化錯誤碼不體現版本號和錯誤等級信息全部正常,但不得不填充錯誤碼時返回五個零:00000錯誤碼為字符串類型,共 5 位,分成兩個部分…

win10 anaconda pytorch avalanche-lib 實驗步驟記錄

conda create --name test_python3.10 conda activate test_python3.10 配置conda國內源(北外) conda install pytorch torchvision torchaudio cpuonly -c pytorch pip3 install avalanche-lib -i https://pypi.tuna.tsinghua.edu.cn/simple conda install jupyter jupyte…

[tidb] tiup升級tidb的版本到 v7.1.1

備份 為了避免數據丟失,升級前需要備份當前tidb集群的數據,參考 TiDB 備份與恢復概述 | PingCAP 文檔中心 說明 由于新版本的tidb的tiflash需要cpui支持avx2,所有升級前先驗證當前升級的服務器是否支持avx2。升級的文檔可以參考 使用 TiUP…

Android布局【TableLayout】

文章目錄 說明常見屬性子控件設置屬性 項目結構主要代碼 說明 TableLayout也稱為表格布局 常見屬性 android:collapseColumns:設置需要被隱藏的列的序列號,從0開始android:stretchColumns:設置允許被拉伸的列的列序號,從0開始&…

docker私有鏡像倉庫搭建

1、下載registry鏡像 docker pull registry:2.52、生成登錄私有倉庫的用戶名以及密碼 mkdir -p /opt/registry/auth/ docker run --entrypoint htpasswd registry:2.5 -Bbn username userpwd >> /opt/registry/auth/htpasswd3、創建配置文件 mkdir -p /opt/registry/…

Git - 配置代理 和 取消代理配置

一. 配置代理 (使git走網路代理) git config --global http.proxy socks5://127.0.0.1:1080 git config --global https.proxy socks5://127.0.0.1:1080 其中 1080 是 SOCKS 代理的端口,一般默認 1080,可以在代理工具的設置中查看 地址記錄&#xff1a…

Python中使用隧道爬蟲ip提升數據爬取效率

作為專業爬蟲程序員,我們經常面臨需要爬取大量數據的任務。然而,有些網站可能會對頻繁的請求進行限制,這就需要我們使用隧道爬蟲ip來繞過這些限制,提高數據爬取效率。本文將分享如何在Python中使用隧道爬蟲ip實現API請求與響應的技…

(十八)大數據實戰——Hive的metastore元數據服務安裝

前言 Hive的metastore服務作用是為Hive CLI或者Hiveserver2提供元數據訪問接口。Hive的metastore 是Hive元數據的存儲和管理組件,它負責管理 Hive 表、分區、列等元數據信息。元數據是描述數據的數據,它包含了關于表結構、存儲位置、數據類型等信息。本…

Android Jetpack Compose 中的分頁與緩存展示

Android Jetpack Compose 中的分頁與緩存展示 在幾乎任何類型的移動項目中,移動開發人員在某個時候都會處理分頁數據。如果數據列表太大,無法一次從服務器檢索完畢,這就是必需的。因此,我們的后端同事為我們提供了一個端點&#…

ArcGIS Pro應用—暨基礎入門、制圖、空間分析、影像分析、三維建模、空間統計分析與建模、python融合、案例應用全流程科研能力提升教程

詳情點擊鏈接:ArcGIS Pro應用—暨基礎入門、制圖、空間分析、影像分析、三維建模、空間統計分析與建模、python融合、案例應用全流程科研能力提升教程 第一:GIS及ArcGIS Pro 1.GIS基本原理及常用軟件 2.ArcGIS Pro 安裝與配置 3.ArcGIS Pro 3.0 的新…

C語言自動抓取淘寶商品詳情網頁數據,實現輕松高效爬蟲

你是否曾經遇到過需要大量獲取網頁上的數據,但手動復制粘貼又太過費時費力?那么這篇文章就是為你而寫。今天我們將會詳細討論如何使用C語言實現自動抓取網頁上的數據。本文將會從以下8個方面進行逐步分析討論。 1. HTTP協議的基本原理 在開始之前&…

小白到運維工程師自學之路 第七十三集 (kubernetes應用部署)

一、安裝部署 1、以Deployment YAML方式創建Nginx服務 這個yaml文件在網上可以下載 cat nginx-deployment.yaml apiVersion: apps/v1 #apiVersion是當前配置格式的版本 kind: Deployment #kind是要創建的資源類型,這里是Deploymnet metadata: #metadata是該資源…