React-router v7 第五章(路由懒加载)

懒加载

什么是懒加载

懒加载是一种优化技术,用于延迟加载组件,直到需要时才加载。这样可以减少初始加载时间,提高页面性能。

懒加载的实现

通过在路由对象中使用 lazy 属性来实现懒加载。

ts 复制代码
import { createBrowserRouter } from 'react-router';
const sleep = (ms: number) => new Promise(resolve => setTimeout(resolve, ms)); // 模拟异步请求
const router = createBrowserRouter([
    {
        Component: Layout,
            {
                path: 'about',
                lazy: async () => {
                    await sleep(2000); // 模拟异步请求
                    const Component = await import('../pages/About'); // 异步导入组件
                    console.log(Component);
                    return {
                        Component: Component.default,
                    }
                }
            },
        ],
    },
]);

当切换到 about 路由时,才会进行加载

如果配置了 loader 则每次都会进入loading状态,如果没有配置 loader 则只执行一次。

体验优化

例如 about 是一个懒加载的组件,在切换到 about 路由时,展示的还是上一个路由的组件,直到懒加载的组件加载完成,才会展示新的组件,这样用户会感觉页面卡顿,用户体验不好。

使用状态优化useNavigation

速查文档useNavigation

  • src/layout/Content/index.tsx
ts 复制代码
import { Outlet, useNavigation } from 'react-router';
import { Alert, Spin } from 'antd';
export default function Content() {
    const navigation = useNavigation();
    console.log(navigation.state);
    const isLoading = navigation.state === 'loading';
    return <div>
        {isLoading ? <Spin size='large' tip='loading...'  >
            <Alert description="小满zs小满zs小满zs小满zs小满zs小满zs小满zs小满zsv"   message="加载中" type='info' />
        </Spin> : <Outlet />
        }
    </div>
}

性能优化

使用懒加载打包后,会把懒加载的组件打包成一个独立的文件,从而减小主包的大小,等用到的时候才会进行加载。

相关推荐
卡布叻_星星4 小时前
前端JavaScript笔记之父子组件数据传递,watch用法之对象形式监听器的核心handler函数
前端·javascript·笔记
开发加微信:hedian1165 小时前
短剧小程序开发全攻略:从技术选型到核心实现(前端+后端+运营干货)
前端·微信·小程序
YCOSA20258 小时前
ISO 雨晨 26200.6588 Windows 11 企业版 LTSC 25H2 自用 edge 140.0.3485.81
前端·windows·edge
小白呀白8 小时前
【uni-app】树形结构数据选择框
前端·javascript·uni-app
吃饺子不吃馅8 小时前
深感一事无成,还是踏踏实实做点东西吧
前端·svg·图形学
90后的晨仔9 小时前
Mac 上配置多个 Gitee 账号的完整教程
前端·后端
少年阿闯~~9 小时前
CSS——实现盒子在页面居中
前端·css·html
开发者小天9 小时前
uniapp中封装底部跳转方法
前端·javascript·uni-app
阿波罗尼亚9 小时前
复杂查询:直接查询/子查询/视图/CTE
java·前端·数据库
正义的大古10 小时前
OpenLayers地图交互 -- 章节九:拖拽框交互详解
前端·vue.js·openlayers