前端代码分割与懒加载:让你的应用飞起来

前端代码分割与懒加载:让你的应用飞起来

毒舌时刻

代码分割和懒加载?听起来就像是前端工程师为了掩饰自己代码写得太烂而发明的借口。你写的代码那么大,加载时间那么长,不分割能行吗?

你以为随便分割一下代码就能解决性能问题?别做梦了!如果分割策略不合理,反而会导致更多的网络请求,让应用变得更慢。

为什么你需要这个

  1. 减少初始加载时间:通过代码分割,只加载当前页面所需的代码,减少初始加载时间,提高用户体验。
  2. 优化资源利用:只加载用户需要的代码,避免加载不必要的资源,优化内存和带宽使用。
  3. 提高首屏渲染速度:快速加载首屏所需的代码,让用户尽快看到页面内容。
  4. 支持大型应用:对于大型应用,代码分割可以避免打包后的文件过大,导致加载时间过长。

反面教材

// 这是一个典型的不使用代码分割的应用 import React from 'react'; import ReactDOM from 'react-dom'; import Home from './pages/Home'; import About from './pages/About'; import Contact from './pages/Contact'; import Dashboard from './pages/Dashboard'; import Settings from './pages/Settings'; import UserProfile from './pages/UserProfile'; import AdminPanel from './pages/AdminPanel'; import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'; function App() { return ( <Router> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> <Route path="/contact" element={<Contact />} /> <Route path="/dashboard" element={<Dashboard />} /> <Route path="/settings" element={<Settings />} /> <Route path="/user-profile" element={<UserProfile />} /> <Route path="/admin" element={<AdminPanel />} /> </Routes> </Router> ); } ReactDOM.render(<App />, document.getElementById('root')); 

问题

  • 所有页面的代码都打包在一个文件中,导致初始加载时间过长
  • 即使用户只访问首页,也会加载所有页面的代码
  • 大型应用的打包文件会变得非常大,影响加载速度
  • 无法实现按需加载,浪费带宽和内存

正确的做法

React中的代码分割与懒加载

// 使用React.lazy和Suspense实现懒加载 import React, { lazy, Suspense } from 'react'; import ReactDOM from 'react-dom'; import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'; // 懒加载页面组件 const Home = lazy(() => import('./pages/Home')); const About = lazy(() => import('./pages/About')); const Contact = lazy(() => import('./pages/Contact')); const Dashboard = lazy(() => import('./pages/Dashboard')); const Settings = lazy(() => import('./pages/Settings')); const UserProfile = lazy(() => import('./pages/UserProfile')); const AdminPanel = lazy(() => import('./pages/AdminPanel')); // 加载中组件 const Loading = () => <div>Loading...</div>; function App() { return ( <Router> <Suspense fallback={<Loading />}> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> <Route path="/contact" element={<Contact />} /> <Route path="/dashboard" element={<Dashboard />} /> <Route path="/settings" element={<Settings />} /> <Route path="/user-profile" element={<UserProfile />} /> <Route path="/admin" element={<AdminPanel />} /> </Routes> </Suspense> </Router> ); } ReactDOM.render(<App />, document.getElementById('root')); 

Webpack中的代码分割

// webpack.config.js module.exports = { entry: { main: './src/index.js', }, output: { filename: '[name].[contenthash].js', chunkFilename: '[name].[contenthash].chunk.js', }, optimization: { splitChunks: { chunks: 'all', cacheGroups: { vendor: { test: /[\\/]node_modules[\\/]/, name: 'vendors', chunks: 'all', }, }, }, }, }; 

基于路由的代码分割

// 使用React Router和React.lazy实现基于路由的代码分割 import React, { lazy, Suspense } from 'react'; import { BrowserRouter as Router, Routes, Route, Navigate } from 'react-router-dom'; // 懒加载路由组件 const Home = lazy(() => import('./pages/Home')); const About = lazy(() => import('./pages/About')); const Contact = lazy(() => import('./pages/Contact')); const Dashboard = lazy(() => import('./pages/Dashboard')); const Settings = lazy(() => import('./pages/Settings')); const UserProfile = lazy(() => import('./pages/UserProfile')); const AdminPanel = lazy(() => import('./pages/AdminPanel')); // 加载中组件 const Loading = () => ( <div className="loading"> <div className="loading-spinner"></div> <p>Loading...</p> </div> ); // 错误边界组件 class ErrorBoundary extends React.Component { constructor(props) { super(props); this.state = { hasError: false }; } static getDerivedStateFromError(error) { return { hasError: true }; } componentDidCatch(error, errorInfo) { console.error('Error:', error); console.error('Error Info:', errorInfo); } render() { if (this.state.hasError) { return <div>Something went wrong. Please try again later.</div>; } return this.props.children; } } function App() { return ( <Router> <ErrorBoundary> <Suspense fallback={<Loading />}> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> <Route path="/contact" element={<Contact />} /> <Route path="/dashboard" element={<Dashboard />} /> <Route path="/settings" element={<Settings />} /> <Route path="/user-profile" element={<UserProfile />} /> <Route path="/admin" element={<AdminPanel />} /> <Route path="*" element={<Navigate to="/" replace />} /> </Routes> </Suspense> </ErrorBoundary> </Router> ); } export default App; 

基于条件的代码分割

// 基于条件懒加载组件 import React, { lazy, Suspense, useState } from 'react'; // 懒加载重型组件 const HeavyComponent = lazy(() => import('./HeavyComponent')); function App() { const [showHeavyComponent, setShowHeavyComponent] = useState(false); return ( <div> <h1>Home Page</h1> <button onClick={() => setShowHeavyComponent(true)}> Load Heavy Component </button> {showHeavyComponent && ( <Suspense fallback={<div>Loading heavy component...</div>}> <HeavyComponent /> </Suspense> )} </div> ); } export default App; 

毒舌点评

代码分割和懒加载确实能提高应用的性能,但我见过太多开发者滥用这个特性,导致应用变得更加复杂。

想象一下,当你为了分割代码而分割代码,把原本简单的应用拆分成无数个小模块,结果导致网络请求变得更多,加载时间反而增加了。这不是得不偿失吗?

还有那些过度使用懒加载的开发者,连一些轻量级的组件也懒加载,结果导致用户点击按钮后还要等待组件加载,影响用户体验。

所以,在使用代码分割和懒加载时,一定要把握好度。不要为了分割而分割,要根据实际情况来决定哪些代码需要分割,哪些不需要。

当然,对于大型应用来说,代码分割和懒加载是必不可少的。但对于小型应用,过度的代码分割反而会增加开发成本和维护难度。

最后,记住一句话:代码分割和懒加载的目的是为了提高应用的性能和用户体验,而不是为了炫技。如果你的代码分割策略导致应用变得更慢,那你就失败了。

Read more

【大作业-46】基于YOLO12的无人机(航拍)视角的目标检测系统

【大作业-46】基于YOLO12的无人机(航拍)视角的目标检测系统

基于YOLO12的无人机(航拍)视角的目标检测系统 🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳 【大作业-46】基于yolo12的航拍(无人机)视角目标检测与追踪系统 🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳🥳 各位小伙伴大家好,今天我们为大家带来的是基于无人机视角下的目标检测,主要是对常规的行人、车辆这些目标进行检测,并且接着这个机会我们对yolo12的新模块进行一下说明,和之前的内容一样,我们的教程中包含了标注好的数据集、训练好的yolov5、yolov8、yolo11以及yolo12的模型,还有一个配套的图形化界面。本次的数据集包含的类别如下: 0: pedestrian 行人 1: people 人 2: bicycle 自行车 3: car 汽车 4: van 货车 5: truck 卡车 6: tricycle 三轮车 7: awning-tricycle 遮阳篷三轮车 8: bus 公交车 9: motor 摩托车 以下是部分数据示例。

Pico无线串流SteamVR全攻略:从安装到畅玩的完整指南

1. 准备工作:软件安装与环境配置 想要用Pico设备无线串流SteamVR游戏,首先得把必要的软件都安装好。我刚开始折腾的时候也走了不少弯路,现在把最稳妥的安装方案分享给大家。 核心软件清单: * Pico串流助手:这是连接Pico设备和PC的桥梁,分为电脑端和头戴端两个版本 * Steam客户端:Valve的游戏平台,必须安装 * SteamVR:Steam的VR运行时环境 * 87VR游戏大厅(可选):国内玩家常用的VR游戏平台 安装顺序很重要,建议按照这个步骤来: 1. 先去Pico官网下载最新版的串流助手,电脑端和头戴端都要装 2. 安装Steam客户端,建议装在SSD硬盘上,加载速度会快很多 3. 在Steam商店搜索安装SteamVR 4. 如果需要使用87VR平台,可以最后安装 这里有个小技巧:安装SteamVR时,记得把下载区域改成离你最近的服务器。我在北京就选"北京",下载速度直接从2MB/s飙到10MB/s。安装完成后,建议重启一次电脑,确保所有驱动都加载正常。 2. 网络环境优化设置 无线串流对网络要求很高,我测试过不同网络环境

Moon VR Video Player中文版下载地址及使用教程:支持8K/12K+多音轨外挂字幕 Moon VR Video Player中文版、Moon VR播放器下载、VR视频播放器推荐、Ste

Moon VR Video Player中文版下载地址及使用教程:支持8K/12K+多音轨外挂字幕 Moon VR Video Player中文版、Moon VR播放器下载、VR视频播放器推荐、Ste

Moon VR Video Player中文版下载地址及使用教程:支持8K/12K+多音轨外挂字幕 关键词:Moon VR Video Player中文版、Moon VR播放器下载、VR视频播放器推荐、SteamVR播放器、多音轨外挂字幕播放器、8K 12K VR播放 作为一个长期折腾的开发者,这段时间一直在找一款真正稳定、格式兼容性强、支持多音轨和外挂字幕的VR播放器。市面上不少播放器要么格式支持有限,要么在8K以上直接卡顿,更别说复杂场景下的字幕和音轨切换。 这次测试的是 Moon VR Video Player(月亮播放器)v835 + 2.8.18 中文版,整体体验确实比很多常见播放器更完整。下面做一次系统梳理,方便需要的朋友参考。 下载地址 链接:https://pan.quark.cn/s/7c80590579cf 一、

Qwen3-VL电力巡检机器人:输电线路图像缺陷识别

Qwen3-VL电力巡检机器人:输电线路图像缺陷识别 在山区蜿蜒的高压铁塔之间,一架无人机正缓缓飞行,镜头扫过锈迹斑斑的金具、悬挂的绝缘子串和微微弧垂的导线。这些画面实时回传到边缘服务器,几秒钟后,系统自动标记出一处“导线断股风险”,并生成报告:“位于第12号杆塔C相小号侧约3米处,金属丝断裂呈放射状,置信度92%,建议72小时内安排带电作业处理。”——这不是科幻场景,而是基于Qwen3-VL视觉-语言模型构建的智能巡检系统的日常。 传统电力巡检依赖人工登塔或望远镜远观,不仅效率低、覆盖有限,还面临高空作业安全风险。即便引入早期AI检测模型,也常受限于样本不足、误报率高、结果不可解释等问题。而如今,随着多模态大模型的发展,尤其是像Qwen3-VL这类具备“视觉理解+语义推理”双重能力的模型出现,我们终于迎来了真正意义上的“看得懂”的AI巡检时代。 从“看见”到“看懂”:Qwen3-VL的核心突破 Qwen3-VL是阿里巴巴通义千问系列中功能最强的多模态大模型,它不再只是把图像当作像素块来分类,而是像一位经验丰富的电力工程师那样去“阅读”图像——能定位异常、分析成因、评估风险,