Next.js 开发指​南(GitHub 115k star​)

Next.js 是一个构建于 Node.js 之上的开源 Web 开发框架,它扩展了最新的 React 特性,集成了基于 Rust 的 JavaScript 工具,可以帮助你快速创建全栈 Web 应用 (full-stack Web applications) 。

对于有一定 React 基础的同学,Next.js 毫无疑问是进阶全栈工程师的最佳选择!

React 官方文档优先推荐的创建项目的方式便是使用 Next.js。目前 Next.js 在 GitHub 已有 115k star,Npm 周下载量 495W 左右,堪称最受欢迎的 Node.js 开发框架之一

c3d2fc6f95874a5390ca07f1868b8321.png 

 

Next.js 于 2016 年底开源发布,历经 7 年的发展,各种解决方案和社区生态已经十分完善。Next.js 更是于 2022 年底推出了支持 React Server Components 的颠覆性的 v13 版本。

在此版本,Next.js 推出了全新的 App Router 模式,同时优化升级了构建工具,为开发者带来了截然不同的开发体验。App Router 于 2023 年 5 月发布的 v13.4 版本进入稳定化。2023 年 10 月,Next.js 发布 v14 版本,Server Actions 也进入稳定化。这本小册便是基于目前最新的 v14 版本。

Next.js 提供开箱即用的 create-next-app脚手架,内置支持 TypeScript、ESLint,零配置即可实现自动编译和打包。支持服务端渲染(SSR)客户端渲染(CSR)静态站点生成(SSG)增量静态再生(ISR)、以及流式加载(Streaming)。v13 版本提供了基于 React Server Component 全新的路由解决方案 App Router 以及服务端数据更改方案 Server Actions,当然不止这些,Next.js 同时提供了现代 Web 应用开发常见的解决方案如:路由、渲染、中间件、数据获取、缓存、样式、国际化、元数据、Edge Runtime 等。

尽管是在业界非常受欢迎的框架,但 Next.js 文档在国内汉化方面十分落后,能搜到的中文文档基本都停留在非常老的版本且处于无人维护状态, 而 Next.js 官方文档早已全部重写,提供了多达百篇的详细介绍。加上 Next.js 2022 年底推出 v13 版本,提供了全新的功能,然而这些内容在国内也没有系统完整的介绍,能搜到的更多是单篇的粗略介绍,技术细节寥寥。

这就导致大家在使用 Next.js 的时候可以快速上手,但对于高阶的 API 却知之甚少。有更简单便捷的实现方案却不知道,对于一些细枝末节上的问题需要多次深入英文文档翻找,对于一些没有过多解释的地方更需要自己反复测试和理解,这无疑增大了使用 Next.js 的成本。

笔者曾经完整的整理过 TypeScript 文档,啃过 ECMAScript 规范,阅读英文文档倒也算顺畅,日常项目中也有在使用 Next.js,对于 Next.js 有一些自己的心得。为了帮助大家系统全面的掌握 Next.js,这本小册将分为“基础篇、实战篇、原理篇、面试篇”四大板块:

基础篇: 基于最新的 Next.js 官方文档,循序渐进讲解 Next.js App Router、高级路由功能、路由处理程序、中间件、数据获取与缓存、React Server ComponentStreamingEdge RuntimeTailwind CSS、内置优化组件、MDX、静态导出、路由段配置、环境变量、Draft ModeNext CLI 及配置项、国际化、常用 API 方法等内容。内容上力求做到详尽无遗漏,细节上添加多处解释和示例帮助大家理解,希望能将此本小册作为大家开发 Next.js 项目时的必备指导手册。

实战篇: 学技术尤其不能纸上谈兵,基础篇的知识细节也许过于零碎,实战篇的目的在于帮助你将这些知识融会贯通。我们会写 3 个完整的全栈项目,包括:

  1. React Notes 项目(目的在于深入理解服务端组件、客户端组件的特性)
  2. 博客项目(目的在于深入理解 Next.js 渲染方式与 MDX)
  3. 移动端 HTML5 项目 (仿 APP 样式,目的在于学习 Next.js 最佳实践)

相关的技术选型有 Ant Design + MongoDB + Mongoose + Redis + Nginx,会提供完整的源码供大家调试学习。

源码篇: Next.js 的源码阅读不算容易,我将从源码的角度帮助大家理解 Next.js 的运行原理与实现,让大家在使用 Next.js API 的时候,知其然知其所以然。遇到问题的时候,能追根溯源,彻底的解决问题。

面试篇: 最后,我会对面试中常问的 Next.js 相关问题做一份整理,告诉大家解题思路的同时提供一份自己的答案,帮助大家在面试的时候有所准备。

 

现在,低调务实优秀的中国好青年们,让我们一起开始学习 Next.js 吧!

你会学到什么?

  1. 循序渐进、系统全面的的建立 Next.js 知识体系;
  2. 学习 Next.js 最新的技术特性,了解技术前沿实践;
  3. 了解 Next.js 的运行原理,知其所以然;
  4. 一本可供开发 Next.js 项目时随时翻阅的技术指导手册;
  5. 一份关于 Next.js 的面试问题指导。

适宜人群

  • 有一定 React 基础,想进阶全栈开发的前端工程师;
  • 对 Next.js 感兴趣希望系统学习的同学;
  • 低调务实优秀的中国好青年。

82684a9a13c34a3dab9f3b1afd589f69.png

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/415674.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Kubernetes部署ingress

文章目录 环境部署ingress可以访问 registry.k8s.io 的环境不能访问 registry.k8s.io 的环境手工部署总结 测试ingress参考 环境 RHEL 9.3Docker Community 24.0.7minikube v1.32.0 部署ingress 可以访问 registry.k8s.io 的环境 通过minikube启用 ingress : m…

【前沿技术杂谈:智能对话的未来】深入比较ChatGPT与文心一言

【前沿技术杂谈:智能对话的未来】深入比较ChatGPT与文心一言 引言主体智能回复语言准确性知识库丰富度 深入分析:ChatGPT与文心一言的技术对比技术架构和算法数据处理和隐私用户界面和体验 应用场景分析未来展望技术进步的趋势潜在的挑战对社会的影响 结…

Kotlin 移动端多平台

支持多平台编程是 Kotlin 的主要优势之一。它减少了为不同平台编写和维护相同代码所花费的时间,同时保留了本机编程的灵活性和优势。 1. 基本概念 KMM:Kotlin Multiplatform for mobile(移动设备的 Kotlin 多平台) KMM 多平台的主…

最新ChatGPT/GPT4科研应用与AI绘图及论文高效写作

详情点击链接:最新ChatGPT/GPT4科研应用与AI绘图及论文高效写作 一OpenAI 1.最新大模型GPT-4 Turbo 2.最新发布的高级数据分析,AI画图,图像识别,文档API 3.GPT Store 4.从0到1创建自己的GPT应用 5. 模型Gemini以及大模型Clau…

大数据开发之Kafka(概述、快速入门、生产者)

第 1 章:Kafka概述 1.1 定义 Kafka是一个分布式的基于发布/订阅模式的消息队列,主要应用于大数据实时处理领域。 发布/订阅:消息的发布者不会将消息直接发送给特定的订阅者,而是将发布的消息分为不同的类别,订阅者只…

机器学习算法理论:贝叶斯

贝叶斯定理对于机器学习来说是经典的概率模型之一,它基于先验信息和数据观测来得到目标变量的后验分布。具体来说,条件概率(也称为后验概率)描述的是事件A在另一个事件B已经发生的条件下的发生概率,公式表示为P(A|B)&a…

Vue-23、Vue收集表单数据

1、效果 2、代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>收集表单数据</title><script type"text/javascript" src"https://cdn.jsdelivr.net/npm/vue2/dist/vue.js…

10个常考的前端手写题,你全都会吗?

前言 &#x1f4eb; 大家好&#xff0c;我是南木元元&#xff0c;热爱技术和分享&#xff0c;欢迎大家交流&#xff0c;一起学习进步&#xff01; &#x1f345; 个人主页&#xff1a;南木元元 今天来分享一下10个常见的JavaScript手写功能。 目录 1.实现new 2.call、apply、…

VUE--组件通信(非父子)

一、非父子通信 --- event bus 事件总线 作用&#xff1a;非父子组件之间进行简易的消息传递 步骤&#xff1a; 1、创建一个都能访问到的事件总线&#xff08;空vue实例&#xff09;--- utils/EventBus.js import Vue from vue export default new Vue({}) 2、 接收方&…

Golang个人web框架开发-学习流程

Golang-个人web框架 github仓库创建github仓库 web框架学习开发周期第一阶段--了解第一阶段思考小结 第二阶段第三阶段 github仓库 github地址&#xff1a;ameamezhou/golang-web-frame 后续还将继续学习更新 创建github仓库 设置免密登录 ssh-keygen 一路回车就OK 上面有告…

flutter使用get依赖实现全局loading效果,弹窗loading状态

get dialog的官网文档&#xff1a;GetDialogRoute class - dialog_route library - Dart API 可以使用Get.dialog()方法来创建一个自定义的加载弹窗&#xff0c;get框架是支持自定义弹窗效果的&#xff0c;所以我们就使用这个方式来自定义一个弹窗效果&#xff0c;并且点击遮罩…

Ubuntu使用QtCreator + CMake 开发C/C++程序

平台 OS: Ubuntu 20.04 cmake: 3.16.3 IDE: Qt Creator 4.11.1 Based on Qt 5.14.1 (GCC 5.3.1 20160406 (Red Hat 5.3.1-6), 64 bit) Built on Feb 5 2020 12:48:30 From revision b2ddeacfb5 Copyright 2008-2019 The Qt Company Ltd. All rights reserved. The program …