Remix Client/Server 架构

Remix 框架是服务端渲染架构,当路由请求时生成 HTML 并返回浏览器。这种 SSR 是如何实现的呢?如果不使用 Remix 这种框架,可以在服务器段启动一个无头浏览器进行页面渲染并返回,代价就是要在服务器上启动一个 Chrome 服务,还要做一些定制,Dom 处理等等。

Remix的做法是直接调用调用 React 渲染函数, 它封装了一个 Handler 来做服务端渲染,React在浏览器中进行渲染时也是生成HTML 片段,并最终添加到 HTML DOM 树中。Remix 这个 Handler 做了同样的处理,只是上下文变成 NodeJS,NodeJS 不能提供做浏览器内置的功能,因此,并不是所有的组件都可以转换,如果要依赖 Dom 上某些状态才能渲染出来,NodeJS 上下文文中没有这些对象的,例如 document 这样的对象,那就是无法渲染的,只能在浏览器中进行渲染。

所以,Remix 并不是简单的将组件渲染成 HTML 并返回,Remix中将组件分成 Server 和 Client,Server 是服务端处理,例如数据库操作等,Client 是在浏览器中进行渲染的部分,同时 Remix 对于 Client 也做了很多优化的处理,例如并发,这是为什么 Remix 的应用运行会比较快,从开始设计的时候,它就考虑了弱网的情况。对于那些比较依赖浏览器环境的组件,服务器端不渲染而是交给客户端进行渲染。

下面我来看一下,Remix 的编译是如何工作,Remix 通过 npx remix vite:build进行编译,并在 build 目录下生成 Client 和 Server相关文件。
在这里插入图片描述
默认Remix 通过 Remix-Serve 启动,为了debug 方便,我们改为 Express Server。

npm i express @remix-run/express# 创建 Server,根目录下创建 server.js
import { createRequestHandler } from "@remix-run/express";
import express from "express";// notice that the result of `remix vite:build` is "just a module"
import * as build from "./build/server/index.js";const app = express();
app.use(express.static("build/client"));// and your app is "just a request handler"
app.all("*", createRequestHandler({ build }));app.listen(3000, () => {console.log("App listening on http://localhost:3000");
});

启动Debug,访问 local host:3000,服务器端调用了 renderToPipeableStream 方法返回Html。

在这里插入图片描述
通过网络可以看到HTML 返回了,但是这里并没有返回Client 的代码。

在这里插入图片描述
AceEditor 并没有返回,是交由客户端进行渲染的。
在这里插入图片描述
AceEditor 是在浏览器渲染完成HTML 之后才进行渲染的,先执行服务器端渲染,再执行客户端渲染。
在这里插入图片描述
Remix在 SSR 生成的过程了坐了各种优化,使得渲染在不同端进行,从而增大灵活性以适应多种场景。

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

萤火虫优化算法(Firefly Algorithm)

注意:本文引用自专业人工智能社区Venus AI 更多AI知识请参考原站 ([www.aideeplearning.cn]) 算法背景 萤火虫优化算法,是由剑桥大学的Xin-She Yang在2009年提出的一种基于群体智能的优化算法。它的灵感来源于萤火虫在夜晚闪烁…

[算法面试]_01_L1和L2正则化,为什么L1正则化更容易导致稀疏?

本人今年参加了很多面试,也有幸拿到了一些大厂的offer,整理了众多面试资料,后续还会分享众多面试资料。 整理成了面试系列,由于时间有限,每天整理一点,后续会陆续分享出来,感兴趣的朋友可关注收…

OBS插件--复合模糊

复合模糊 复合是一款滤镜插件,支持多种模糊类型和多种蒙版效果。支持模糊源的部分显示区域,可以反选区域进行模糊,这个功能对于场景部分区域需要遮盖非常实用。 下面截图演示下操作步骤: 首先,打开 OBS直播助手 在…

2024年数维杯数学建模

高质量原创论文已完成 需要的私我

MySQL性能优化:MySQL中的隐式转换造成的索引失效

目录 前言数据准备SQL测试分析和总结 前言 数据库优化是一个任重而道远的任务,想要做优化必须深入理解数据库的各种特性。在开发过程中我们经常会遇到一些原因很简单但造成的后果却很严重的疑难杂症,这类问题往往还不容易定位,排查费时费力最…

微服务下的技术栈架构解析

微服务是一种架构风格,它将一个复杂的应用拆分成多个独立自治的服务,每个服务负责应用程序中的一小部分功能。这些服务通过定义良好的API进行通信,通常是HTTP RESTful API或事件流。微服务架构的主要特点包括单一职责、自治性、可独立部署和扩…

力扣例题(用栈实现队列)

目录 链接. - 力扣(LeetCode) 描述 思路 push pop peek empty 代码 链接. - 力扣(LeetCode) 描述 思路 push 例如我们将10个元素放入栈中,假设最左边为栈顶,最右侧为栈底 则为10,9,8,7,6,5,4,3,…

PyCharm2024安装教程

PyCharm是一款功能强大的Python集成开发环境(IDE),它提供了许多工具和功能来帮助开发者编写、调试和测试Python代码。以下是使用PyCharm的基本步骤: 安装PyCharm:首先,你需要从JetBrains官方网站下载并安装…

关于画图-一次性搞定各类高级论文作图及配色

关于画图-一次性搞定各类高级论文作图及配色 图(Figure)可以让各类论文的结果更加直观,有时候一张图片比一大段文字更有说服力。 但许多新手作者可能会有一连串的疑惑:数据这么多,什么时候该做什么类型的图&#xff…

事务的基础

📝个人主页:五敷有你 🔥系列专栏:面经 ⛺️稳中求进,晒太阳 事务的基础 1)事务 事务是:一组操作的集合 ,他是不可分割的工作单位。事务会把所有操作作为一个整体一起向系统提…

Linux:Figshare网站文件下载(非浏览器)

参考aws亚马逊云下载figshare内容 Linux wget -c 下载网页内容crul -C_figshare怎么下载数据-CSDN博客 尝试一下 mamba search awscli mamba install awscli2.15.48 aws --version通过网页获取下载链接 比如: https://s3-eu-west-1.amazonaws.com/pfigshare-u-…

关键点检测——面部情绪数据集

引言 亲爱的读者们,您是否在寻找某个特定的数据集,用于研究或项目实践?欢迎您在评论区留言,或者通过公众号私信告诉我,您想要的数据集的类型主题。小编会竭尽全力为您寻找,并在找到后第一时间与您分享。 …

重写muduo之TcpServer

目录 1、Callbacks.h 2、TcpServer.h 3、TcpServer.cc 1、Callbacks.h 回调操作 #pragma once#include <memory> #include <functional>class Buffer; class TcpConnection;using TcpConnectionPtrstd::shared_ptr<TcpConnection>; using ConnectionCall…

解锁Spring Boot数据映射新利器:深度探索MapperStruct

解锁Spring Boot数据映射新利器&#xff1a;深度探索MapperStruct MapperStruct 是一个强大的 Java 映射工具&#xff0c;它的主要作用是简化对象之间的映射操作。在 Spring Boot 应用程序中&#xff0c;MapperStruct 通常用于将领域模型对象&#xff08;Domain Model&#xff…

WPF之工具栏菜单栏功能区。

1&#xff0c;菜单栏&#xff0c;工具栏&#xff0c;状态栏。 1.1&#xff0c;Menu中可添加菜单分隔条<Separator></Separator>作为分割线&#xff0c;使用Separator可以通过改变其template来自定义&#xff0c;Separator是无焦点的&#xff0c;如果简单的在MenuIt…

App下载绑定新方式:Xinstall带来的革命性改变

在当今数字化时代&#xff0c;移动应用&#xff08;App&#xff09;已成为企业与用户之间互动的重要桥梁。然而&#xff0c;对于许多企业来说&#xff0c;App下载与用户关系绑定一直是一个令人头疼的问题。这时&#xff0c;Xinstall应运而生&#xff0c;为企业提供了一种全新的…

mybatis 跨库查询 mysql

跨库&#xff0c;表关联的查询&#xff0c;实现起来很简单&#xff1a; select a.uid from ucenter.user a , database user_profile b where a.uid b.uid;只要在表的前边加上库名即可。 这个是我项目中xml 中的一个例子&#xff0c;项目采用的是springmvc,持久层框架就是my…

理解导数(x^n求导后nx^n-1)

以下都是为了方便理解 微小量是 t M(x)是一个函数 M 在 x 处的斜率 M 在 x 处的导数 垂直距离 平移距离 M ( x t ) − M ( x ) ( x t ) − x M在x处的斜率 M在x处的导数 \dfrac{垂直距离}{平移距离} \dfrac{M\left( xt\right) -M\left( x\right) }{(x t) -x} M在x处的斜…

探讨 vs2019 c++ 里函数指针与函数类型在使用上的语法区别

&#xff08;1&#xff09;咱们可以用 decltype &#xff08;&#xff09; 来判断函数的类型。但以这个类型定义有用的可指向已存在函数的变量&#xff0c;却行不通。测试如下&#xff1a; 如果把上面的注释去掉会报错&#xff1a; 所以函数类型只有语法意义。但在使用上没有函…

0X JavaSE-- UML、

# Unified Modeling Language UML 统一建模语言 UML 是一种图形化的语言。 UML 不是专门为 Java 准备的。 只要是面向对象的编程语言&#xff0c;开发前的设计&#xff0c;都需要画 UML 图进行系统设计。 最常用的四个 UML 图是 类图&#xff08;Class Diagram&#xff09;&…