Next.js 加载页面及流式渲染(Streaming)

2024-06-11 08:04

本文主要是介绍Next.js 加载页面及流式渲染(Streaming),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Next.js 加载页面及流式渲染(Streaming)

在现代的 Web 应用开发中,用户体验是至关重要的。快速响应的页面加载和流畅的用户界面可以显著提升用户的满意度。而加载页面(Loading Page)和流式渲染(Streaming)在这其中起到了关键作用。

一、加载页面的作用

1.1 提升用户体验

加载页面在用户等待数据加载或页面渲染完成时提供了视觉反馈,避免了用户面对空白屏幕的不安和困惑。一个设计良好的加载页面可以让用户感受到应用正在积极工作,从而减少他们的焦虑感。

1.2 避免页面布局变化

在数据加载完成之前显示加载页面,可以避免页面布局在数据加载后突然变化,防止因内容突然出现而导致的页面跳动。这对于保持一致的用户体验至关重要。

1.3 提供品牌曝光机会

加载页面还可以作为品牌曝光的机会。设计一个与品牌形象一致的加载动画或标志,可以在提升用户体验的同时加强品牌记忆。

二、Next.js 加载页面的实现

在 Next.js 中,实现加载页面主要有以下几种方法:

2.1 利用全局 CSS

可以通过全局 CSS 文件在 _app.js 文件中定义加载页面的样式。例如:

// pages/_app.js

import '../styles/globals.css';
import { useState, useEffect } from 'react';function MyApp({ Component, pageProps }) {const [loading, setLoading] = useState(true);useEffect(() => {const handleRouteChange = (url) => {setLoading(true);};const handleRouteComplete = (url) => {setLoading(false);};Router.events.on('routeChangeStart', handleRouteChange);Router.events.on('routeChangeComplete', handleRouteComplete);Router.events.on('routeChangeError', handleRouteComplete);return () => {Router.events.off('routeChangeStart', handleRouteChange);Router.events.off('routeChangeComplete', handleRouteComplete);Router.events.off('routeChangeError', handleRouteComplete);};}, []);return (<>{loading ? <Loading /> : <Component {...pageProps} />}</>);
}function Loading() {return (<div className="loading"><div className="spinner"></div></div>);
}export default MyApp;

2.2 使用 Next.js 内置的动态加载

Next.js 提供了动态加载组件的功能,可以在加载组件时显示加载指示器:

import dynamic from 'next/dynamic';const DynamicComponentWithLoading = dynamic(() => import('../components/YourComponent'), {loading: () => <p>Loading...</p>,
});export default function Page() {return <DynamicComponentWithLoading />;
}

三、流式渲染(Streaming)

3.1 什么是流式渲染

流式渲染是一种渐进式的页面渲染技术,可以在服务器端逐步发送页面内容到客户端,而不是等待整个页面准备好后再发送。这样可以显著减少首次内容绘制(First Contentful Paint,FCP)时间,提升用户感知性能。

3.2 Next.js 的流式渲染支持

Next.js 12 引入了对 React 18 流式渲染的支持,通过 next/server 模块可以轻松实现流式渲染。例如:

import { renderToReadableStream } from 'react-dom/server';
import { NextResponse } from 'next/server';export async function middleware(req) {const stream = await renderToReadableStream(<YourComponent />);return new NextResponse(stream);
}

3.3 流式渲染的优势

更快的首屏渲染:由于流式渲染可以在数据加载的同时发送已经准备好的部分内容,用户可以更快地看到页面的部分内容,而不是等待整个页面加载完毕。
更好的用户体验:用户可以逐步看到页面的内容,减少等待的焦虑感和不确定感。
资源优化:通过流式渲染可以优化服务器资源的使用,提升整体应用的性能。

这篇关于Next.js 加载页面及流式渲染(Streaming)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050604

相关文章

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点:

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

SpringBoot项目删除Bean或者不加载Bean的问题解决

《SpringBoot项目删除Bean或者不加载Bean的问题解决》文章介绍了在SpringBoot项目中如何使用@ComponentScan注解和自定义过滤器实现不加载某些Bean的方法,本文通过实... 使用@ComponentScan注解中的@ComponentScan.Filter标记不加载。@C

springboot 加载本地jar到maven的实现方法

《springboot加载本地jar到maven的实现方法》如何在SpringBoot项目中加载本地jar到Maven本地仓库,使用Maven的install-file目标来实现,本文结合实例代码给... 在Spring Boothttp://www.chinasem.cn项目中,如果你想要加载一个本地的ja

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

使用JavaScript将PDF页面中的标注扁平化的操作指南

《使用JavaScript将PDF页面中的标注扁平化的操作指南》扁平化(flatten)操作可以将标注作为矢量图形包含在PDF页面的内容中,使其不可编辑,DynamsoftDocumentViewer... 目录使用Dynamsoft Document Viewer打开一个PDF文件并启用标注添加功能扁平化