isomorphic-javascript 相关问题

同构网站可以在服务器和浏览器中运行。它们授予代码重用,SEO和页面加载速度提升,同时仍然使用JS编写的接口。 Node.js最常用于服务器JavaScript引擎。

如何将 Vite 中导入的“原始”图像编码为 Base64?

我有一个JPG,我在Vite中导入它,就像从“whatever.jpg?raw”导入数据一样。我的目标是将生成的原始 JPEG 字符串编码为数据 URI,如 。 JPEG 我...

回答 1 投票 0

原生 Node.js 和浏览器加密的同构代码

有一个 isomorphic-webcrypto 假装这样做,但实际上并没有:它为每个目标构建单独的构建。 有一种高贵的加密方法可以做到这一点,但它基于 if-else 条件和 f...

回答 2 投票 0

在服务器端 asp.net 上进行 angularjs 渲染

我在前端使用了 angularjs 框架,在后端使用了 asp net mvc 来开发我的网络应用程序。 如你所知,AngularJS 在 SEO 方面有一个重大缺陷。有一些解决方案,例如使用

回答 1 投票 0

React 16:警告:由于状态<div>,预计服务器 HTML 将在 <div> 中包含匹配的

我使用 SSR 时收到以下错误 警告:服务器 HTML 预计在 中包含匹配的 。 检查组件 m 上的浏览器宽度时,问题出在客户端...... 我使用 SSR 时遇到以下错误 Warning: Expected server HTML to contain a matching <div> in <div>. 问题出在客户端,检查组件安装时的浏览器宽度,然后设置组件的状态以呈现其移动版本。 但是服务器默认容器的桌面版本,因为它不知道浏览器宽度。 遇到这样的情况我该如何处理?我可以以某种方式检测服务器上的浏览器宽度并在发送到客户端之前渲染移动容器吗? 编辑:现在我决定在组件安装时渲染容器。这样,服务器端和客户端最初都不会渲染任何内容来阻止此错误。 我仍然愿意接受更好的解决方案 这将解决问题。 // Fix: Expected server HTML to contain a matching <a> in const renderMethod = module.hot ? ReactDOM.render : ReactDOM.hydrate; renderMethod( <BrowserRouter> <RoutersController data={data} routes={routes} /> </BrowserRouter>, document.getElementById('root') ); 盖茨比 最近的 gatsby 功能标志(在 2020 年 12 月 v2.28 中引入)能够在开发环境中服务器端渲染页面。 此标志默认设置为 true。在这种情况下,您可能会在控制台中看到此错误消息 Warning: Expected server HTML to contain a matching <div> in <div>. 您可以在 gatsby.config.js 文件中禁用此标志: module.exports = { flags: { DEV_SSR: false, } } 文档:https://www.gatsbyjs.com/docs/reference/release-notes/v2.28/#feature-flags-in-gatsby-configjs 出现此消息的原因也可能是错误的代码,无法在 SSR 和 CSR 之间呈现一致的内容,因此 hydrate 无法解析。 例如SSR返回: ... <div id="root"> <div id="myDiv">My div content</div> </div> ... 企业社会责任回归时: ... <div id="root"> <div id="anotherDiv">My other div content</div> </div> ... 在这种情况下,最好的解决方案不是安装库或关闭 hydrate,而是实际修复代码中的不一致之处。 暂时从 <script src="/react-bundle-path.js"></script> 中删除 index.js 有助于将 SSR 渲染的确切内容与 CSR hydrate 渲染的内容进行比较。 当前接受的答案与 TypeScript 配合得不好。这对我有用。 <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <link rel="shortcut icon" href="/favicon.ico" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> </head> <body> <noscript> You need to enable JavaScript to run this app. </noscript> <div id="root"></div> </body> </html> import React from "react" import { hydrate, render } from "react-dom" import BrowserRouter from "./routers/Browser" const root = document.getElementById("root") var renderMethod if (root && root.innerHTML !== "") { renderMethod = hydrate } else { renderMethod = render } renderMethod(<BrowserRouter />, document.getElementById("root")) 来自 https://github.com/vercel/next.js/discussions/17443#discussioncomment-87097 仅应在浏览器中运行的代码应在useEffect内执行。这是必需的,因为第一次渲染应该与服务器的初始渲染匹配。如果你操纵这个结果,它会产生不匹配,并且 React 将无法成功地水合页面。 当您在 window 内运行仅限浏览器的代码(例如尝试访问 useEffect)时,它会在水合后发生 👍 HTTP 客户端提示可以帮助您。 另一篇关于客户提示的有趣文章。 我的解决方案是使用像 express-useragent 这样的中间件来检测浏览器用户代理。 然后,在服务器端,按照以下规则创建一个类似viewsize的{width, height} if (ua.isMobile) { return {width: 360, height: 480} } if (ua.isDesktop) { return {width: 768, height: 600} } return {width: 360, height: 480} // default, and for bot 那么,某种程度上它仍然是SSR中的响应式设计。 就我而言,我必须将“Provider of Redux”和“Toaster”放置在根布局的 body 标记内。 export default function RootLayout({ children }) { return ( <> <html lang="en"> <body className={inter.className}> <Toaster position="top-right" reverseOrder={false} toastOptions={{ duration: 1000 }} /> <StoreProvider> {children} </StoreProvider> </body> </html> </> ) }

回答 8 投票 0

Nextjs + Docker-Compose:如何在客户端解析容器主机名?

这里是Docker的新手。我的Nextjs应用程序一直遇到一个令人困惑的障碍,该应用程序与API和数据库容器一起在自己的容器中运行。我的Nextjs应用程序使用......>

回答 1 投票 0

用React动态加载样式表

我正在建立一个CMS系统来管理营销目标网页。在“编辑登录页面”视图上,我希望能够为用户正在编辑的任何登录页面加载相关的样式表。怎么...

回答 3 投票 17

同构应用程序中的条件内存缓存用法

我具有同构应用程序,该应用程序依赖于具有实现微服务api的类的包。我有实现微服务api的包并扩展了其他类-基本类到我所有的...

回答 1 投票 1

使用React路由器的服务器端身份验证流程

我想知道如果我的应用程序正在渲染服务器端,如何使用React Router精确实现身份验证流程 场景: 当用户第一次到达应用程序时,我们调用onEnter路由...

回答 1 投票 3

使用React-Router进行服务器端渲染

我正在尝试使用最简单的Hello World示例在服务器上运行react router,无论我做什么,回调中的props始终是未定义的。 经过两天的尝试,AP...

回答 1 投票 0

React-Router Webpack将服务器逻辑从捆绑到客户端JavaScript中排除在外

我正在制作一个同构的React应用程序,但是现在我被困在弄清楚如何使用react router和webpack将服务器端逻辑排除在绑定到客户端javascri...

回答 0 投票 1

Angular 1.x版本的通用示例

我进行了研究,但发现此问题没有任何结果。 我想学习如何使用Angular .x版本实现UJ系统。 有什么例子或指南吗 我发现Angular 缺少示例,但是我的...

回答 0 投票 0

(同构)路由和基于ajax的反应组件的后端呈现

我正在尝试构建一个同构反应应用程序。我使用express作为后端。我有一个带有App组件的静态路由器。我捕获任何请求并像这样使用renderToString :(下面的代码是......

回答 1 投票 1

package.json中节点和浏览器的不同主要入口点

在同构反应应用程序中,我有myModule,它在节点和浏览器环境中的行为应该不同。我想在package.json中为myModule配置这个分裂点:package.json {“...

回答 4 投票 6

如果需要来自第三方API的数据,如何从next.js导出静态HTML页面?

我正在使用next.js来构建静态HTML网页。我的一个网页需要来自第三方API的数据,我想在构建时获取数据并将其烘焙到生成的HTML中。我不想要这个电话......

回答 1 投票 1

从React(Isomorphic应用程序)进行API调用时出现“Access-Control-Allow-Origin”问题

我使用React和Express遇到了同构JavaScript应用程序的问题。当我的组件安装componentDidMount(){const url = ...时,我正在尝试使用axios.get发出HTTP请求

回答 6 投票 16

Jest Test Babel Error:不允许插件/预设文件导出对象

我正在使用一个非常新的(2017年12月)堆栈的依赖项。当我尝试使用Jest进行同构反应测试时,测试套件会因以下错误而失败:*测试套件无法运行[...

回答 2 投票 4

Server Side React Initial Render导致重复的异步调用

我在服务器上使用react-router 2.0。我的一些顶级路由组件依赖于要获取的异步数据,并使用Redux来管理状态。为了解决这个问题,我正在使用静态fetchData()...

回答 1 投票 3

什么是同构应用?

我一直在阅读有关异构应用程序是什么,为什么这种类型的架构更好等等的多篇不同文章。但是我仍然有一点不确定性是什么意思......

回答 1 投票 4

ssr with react和express并要求stats.json解释

我正在查看底部的代码示例,它是一个react ssr示例:在configureProduction函数中,它有这一行:const clientStats = require('./ assets / stats.json');这是什么 ...

回答 3 投票 8

如何识别react-router Handler在它进入视图之前是NotFound?

我正在开发一个小样板项目,使用node&express与ReactJS进行服务器端渲染。我想知道如何识别回调函数中的Handler变量...

回答 1 投票 2

© www.soinside.com 2019 - 2024. All rights reserved.