React SSR

一、为什么需要SSR呢?

单页面富应用的局限:

  • 之前我们开发的应用程序,如果直接请求可以看到上面几乎没有什么内容。
    在这里插入图片描述

  • 但是为什么我们页面可以看到大量的内容呢?

  • 因为当我们请求下来静态资源之后会执行JS,JS会去请求数据,并且渲染我们想要看到的。

但是这个过程存在另外两个问题:

  • 问题一:首屏显示的速度较慢;
  • 问题二:不利于SEO的优化;

如何解决这个问题呢?

  • 采用服务端渲染;

二、认识SSR和同构?

SSR(Server Side Rendering,服务端渲染),指的是页面在服务器端已经生成了完成的HTML页面结构,不需要浏览器解析;

对应的是CSR(Client Side Rendering,客户端渲染),我们开发的SPA页面通常依赖的就是客户端渲染;

早期的服务端渲染包括PHP、JSP、ASP等方式,但是在目前前后端分离的开发模式下,前端开发人员不太可能再去学习PHP、JSP等技术来开发网页;

不过我们可以借助于Node来帮助我们执行JavaScript代码,提前完成页面的渲染;

什么是同构?
一套代码既可以在服务端运行又可以在客户端运行,这就是同构应用。
在这里插入图片描述

同构是一种SSR的形态,是现代SSR的一种表现形式。

  • 当用户发出请求时,先在服务器通过SSR渲染出首页的内容。
  • 但是对应的代码同样可以在客户端被执行。
  • 执行的目的包括事件绑定等以及其他页面切换时也可以在客户端被渲染;

三、使用React SSR

使用React SSR主要有两种方式:

  • 方式一:手动搭建一个SSR框架;
  • 方式二:使用已经成熟的SSR框架:Next.js

安装Next.js框架的脚手架:

npm install –g create-next-app

创建Next.js项目

create-next-app next-demo

package.json文件:
在这里插入图片描述

四、首页的展示

Next.js默认已经给我们配置好了路由映射关系:

  • 路径和组件的映射关系;
  • 这个映射关系就是在pages中配置相关的组件都会自动生成对应的路径;

默认page/index.js是页面的默认路径:
在这里插入图片描述

五、定义关于页面和页面跳转

定义About页面

在这里插入图片描述

从Home页面跳转到About页面

在这里插入图片描述

六、Layout组件

在这里插入图片描述

我们发现home和about是两个相互独立的组件:

  • 如果它们有一些公共的内容:比如头部、尾部是一样的,是否每个地方都需要写一遍呢?

有两种解决方案:

  • 方案一:自定义一个Layout的组件,将公共的内容放到Layout中;
    在这里插入图片描述

  • 方案二:在_app中编写公共部分的内容;
    在这里插入图片描述

七、Next.js支持各种样式

方式一:全局样式引入
在这里插入图片描述

方式二:module.css
在这里插入图片描述

方式三:默认集成styled-jsx
在这里插入图片描述

方式四:其他css in js方案,比如styled-components

  • 引入相关的依赖;
yarn add styled-components
yarn add -D babel-plugin-styled-components
  • 创建和编辑 .babelrc文件
    在这里插入图片描述

在这里插入图片描述

八、路由的补充

路由的嵌套(子路由):
文件夹的嵌套,最后就可以形成子路由;
在这里插入图片描述
在这里插入图片描述

路由的传参:

  • Next.js中无法通过 /user/:id的方式传递参数;
  • 只能通过 /user?id=123的方式来传递参数;

传递参数有两种办法:

  • Link中的路径;
    在这里插入图片描述

  • Router.push(pathname, query)
    在这里插入图片描述

九、请求数据 - getInitialProps

在这里插入图片描述
在这里插入图片描述

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

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

相关文章

Vue3 组件通信学习笔记

一、父子组件之间通信 父子组件之间如何进行通信呢? 父组件传递给子组件:通过props属性;子组件传递给父组件:通过$emit触发事件; 1.1 父组件传递给子组件 在开发中很常见的就是父子组件之间通信,比如父…

Vue3 slot插槽——(默认插槽、具名插槽、作用域插槽)

一、认识插槽Slot 在开发中,我们会经常封装一个个可复用的组件: 前面我们会通过props传递给组件一些数据,让组件来进行展示;但是为了让这个组件具备更强的通用性,我们不能将组件中的内容限制为固定的div、span等等这…

Vue动态组件和组件缓存

一、切换组件案例 比如我们现在想要实现了一个功能: 点击一个tab-bar,切换不同的组件显示; 这个案例我们可以通过两种不同的实现思路来实现: 方式一:通过v-if来判断,显示不同的组件; 方式二…

Webpack的代码分包Vue3中定义异步组件分包refs的使用

一、默认的打包过程: 默认情况下,在构建整个组件树的过程中,因为组件和组件之间是通过模块化直接依赖的,那么webpack在打包时就会将组件模块打包到一起(比如一个app.js文件中); 这个时候随着项…

组件的v-model Mixin extends

一、组件的v-model 前面我们在input中可以使用v-model来完成双向绑定: 这个时候往往会非常方便,因为v-model默认帮助我们完成了两件事;v-bind:value的数据绑定 和 input的事件监听; 如果我们现在封装了一个组件,其…

Vue3过渡动画实现

一、认识动画 在开发中,我们想要给一个组件的显示和消失添加某种过渡动画,可以很好的增加用户体验: React框架本身并没有提供任何动画相关的API,所以在React中使用过渡动画我们需要使用一个第三方库react-transition-group&…

Vue3 Composition API(一)——setup、reactive、ref、readonly

一、Options API的弊端 在Vue2中,我们编写组件的方式是Options API: Options API的一大特点就是在对应的属性中编写对应的功能模块;比如data定义数据、methods中定义方法、computed中定义计算属性、watch中监听属性改变,也包括生…

dex文件格式二

一. dex文件头(1) magic value在DexFile.c dexFileParse函数中 会先检查magic opt啥是magic opt呢? 我们刚刚从cache目录拷贝出来的那个前面的dey 036就是magic opt在源码中会先解析magic opt,然后重设dexfile指针重设magic opt指针后开始解析magic value这 8 个 字节一般是…

Vue3 Composition API(二)——computed、watchEffect、setup中使用ref

一、computed 在前面我们讲解过计算属性computed:当我们的某些属性是依赖其他状态时,我们可以使用计算属性来处理 在前面的Options API中,我们是使用computed选项来完成的;在Composition API中,我们可以在 setup 函数中…

【Git】笔记1

学习廖雪峰Git教程的笔记 Git是什么: Git是目前世界上最先进的分布式版本控制系统 Git与Github的关系:github是一个用git做版本控制的项目托管平台,它为开源项目免费提供Git存储 Git的创建者:Linus,就是创建了linux的那…

支持字典_手把手教你学Python之字典

字典是一种无序可变的容器,字典中的元素都是"键(key):值(value)"对, “键”和“值”之间用冒号隔开,所有“键值对”放在一对大括号“{}”中,元素之间用逗号分隔。在同一个字典中,“键”必须是唯一的&#xf…

Vue3 Composition API(三)——生命周期钩子、Provide函数 和 Inject函数、封装Hook案例、setup顶层编写方式

一、生命周期钩子 我们前面说过 setup 可以用来替代 data 、 methods 、 computed 、watch 等等这些选项,也可以替代 生命周期钩子。 那么setup中如何使用生命周期函数呢? 可以使用直接导入的 onX 函数注册生命周期钩子; 二、Provide函数 和…

单尺度二维离散小波重构(逆变换)idwt2

clc,clear all,close all; load woman; %单尺度二维离散小波分解。分解小波函数haar [cA,cH,cV,cD]dwt2(X,haar); %单尺度二维离散小波重构(逆变换) Yidwt2(cA,cH,cV,cD,haar); figure; subplot(1,2,1),imshow(X,map),title(原始图像); subplot(1,2,2),imshow(Y,map),title(重构…

python导出数据顿号做分隔符_Python语言和matplotlib库做数据可视化分析

这是我的第51篇原创文章,关于数据可视化分析。阅读完本文,你可以知道:1 Python语言的可视化库—matplotlib?2 使用matplotlib实现常用的可视化?0前言数据记者和信息设计师,David McCandless,在他的TED演讲…

Vue3 高级语法(一)—— h函数、jsx

一、认识h函数 Vue推荐在绝大数情况下使用模板来创建你的HTML,然后一些特殊的场景,你真的需要JavaScript的完全编程的能力,这个时候你可以使用渲染函数 ,它比模板更接近编译器; 前面我们讲解过VNode和VDOM的改变&#…

Vue3 高级语法(二)—— 自定义指令、Teleport、Vue插件

一、认识自定义指令 在Vue的模板语法中我们学习过各种各样的指令:v-show、v-for、v-model等等,除了使用这些指令之外,Vue也允许我们来自定义自己的指令。 注意:在Vue中,代码的复用和抽象主要还是通过组件;通…

Vue-Router4 学习笔记

一、URL的hash 前端路由是如何做到URL和内容进行映射呢?监听URL的改变。 URL的hash也就是锚点(#), 本质上是改变window.location的href属性; 我们可以通过直接赋值location.hash来改变href, 但是页面不发生刷新; hash的优势就是兼容性更好&am…

Vuex4学习笔记

一、Vuex的状态管理 二、Vuex的安装 我们这里使用的是vuex4.x,安装的时候需要添加 next 指定版本; npm install vuexnext三、创建Store 每一个Vuex应用的核心就是store(仓库): store本质上是一个容器,它…

JS高级——手写call()、apply()、bind()

0、call、apply、bind的区别 bind,call,apply的作用都是用来改变this指向的 call方法 call方法的第一个参数是this的指向 后面传入的是一个参数列表(注意和apply传参的区别)。当一个参数为null或undefined的时候,函数中…

js文章QQ空间分享

<!--示例一--> <div id"ckepop" classfeixiangjias> <a href"javascript:" class"jiathis jiathis_txt jtico jtico_jiathis" target"_blank">分享到&#xff1a;</a> <a class"jiathis_button_qzo…