Remix 对比 Next.js :一文深度解析

sxkk20082年前知识分享160

前言

Next.js 是用于服务器端渲染的最流行的 React 框架之一,它流行了很多年,并且被许多开发者所喜爱。

然而,随着 Remix 的开源引入, 开发人员已经开始怀疑哪个框架对他们的应用程序来说更加友好,所以,在本文中,我将对比 Next.js 和 Remix 的一些重要特性,来帮助您选择最佳框架。

路由系统

当谈到路由时,Remix 和 Next.js 之间有许多相似之处。例如, 它们都遵循基于文件的约定式路由系统,并支持动态路由。

相同点 在 Next.js 中, 当你在 /pages 文件夹下创建一个文件, 它将自动设置为路由。

pages/index.js ==> /

pages/users/index.js ==> /users

pages/users/create.js ==> /users/create

Remix 也会自动创建路由. 但是, 你需要在app/routes 文件夹下创建文件。

app/routes/index.js ==> /

app/routes/users/index.js ==> /users

app/routes/users/create.js ==> /users/create

差异性 Remix 路由是基于 react-router 构建的, 并且你可以直接使用 React Hooks, 比如 useParamsuseNavigate。 另一方面, Remix 内置支持嵌套布局的嵌套路由,而 Nest.js 则不支持.

数据加载

web 应用程序中有几种数据加载技术。分别是:

  • (SSR)Server-side rending in the runtime 服务端渲染.
  • (SSG) Static Site Generation 静态生成 + (ISR) Incremental Static Regeneration 增量静态生成 .
  • (CSR)Client-side rending at runtime 客户端渲染.
  • 混合服务端渲染和客户端渲染和静态生成

在 Next.js 中, 开发人员可以自由的选择上述所有方法技术从加载数据,比如我的博客就是使用了 SSG 将文章详情页打成静态资源,新写的文章就使用了增量静态生成,不需要再次打包。

你可以使用getServerSideProps这个方法直接获取数据,并且可以通过 getStaticPropsgetStaticPath 在构建时从服务器端加载数据。以下代码示例显示如何使用 getServerSideProps 加载数据.

export const getServerSideProps = async ({ params, query }) => {
  const id = params.id
  // 通过 url 上的id 获取数据
  // const data= await db.res.query(id)
  return { props: { id, Data } }
}

export default function age({ id, data }) {
  return (
    <div>
      <h1>url 上的id 参数: {id}h1>
      <h2>根据id 插件结果是: {data}h2>
    div>
  )
}

在 Remix 中 ,只支持 SSR 和 CSR,只支持这 2 种。

你必须导出一个 loader 在路由页面,然后使用 useFetcher 这个 Hook 从服务端渲染中获取数据

import { useLoaderData } from 'remix'

export let loader = async ({ params, request }) => {
  const id = params.id
  // 通过 url 上的id 获取数据
  // const data= await db.res.query(id)
  return { id, data }
}

export default function Page() {
  let { id, dataLimit } = useLoaderData()
  return (
    <div>
      <h1>url 上的id 参数: {id}h1>
      <h1>根据id 插件结果是: {data}h1>
    div>
  )
}

Next.js 支持服务器端渲染 (SSR) 、静态站点生成 (SSG) 、增量静态生成 (ISR) 和 CSR (客户端渲染) . 对比,Remix 它仅支持 SSR 和 CSR。

使用 Sessions and cookies

在 Next.js 中没有直接可以操作 cookie 的内置函数。但是像 Cookie.js 这样的流行库可以与 Next.js 或 NextAuth.js 一起使用,比如将用户身份验证数据保存在 cookie 中。

Remix 支持开箱即用的方法操作 cookie 。您可以通过调用函数来生成 cookie,然后序列化或解析数据以存储或读取它.

以下来自 Remix 的代码片段显示了如何在 Remix 中创建用于管理浏览器 cookie 的逻辑函数。

import { createCookie } from 'remix'

const cookie = createCookie('cookie-name', {
  expires: new Date(Date.now() + 60),
  httpOnly: true,
  maxAge: 60,
  path: '/',
  sameSite: 'lax',
  secrets: ['s3cret1'],
  secure: true,
})

样式

在样式方面,Remix 与 Next.js 略有不同。Remix 提供了一种内置技术,可以使用links方法动态添加样式,而 Next.js 支持 Styled-JSX 作为 CSS in JS 方案或者使用 css modules,全局样式只能写在最外层的 app.js 中

function Home() {
	return (
		<div className="container">
  	<h1>My Cart in Next.jsh1><p>Some paragraphp><style jsx>
    	{'
      .container {
        margin: 20px;
      }
      p {
        color: blue;
      }
    `}
   style>div>
 )
}

export default Home

Remix 使用一种简单的方法向页面添加样式,使用 标签 。当页面切换到该页面下自动加载样式原先页面下的样式自动删除,下面的代码片段展示了如何使用links函数以在 Remix 中加载样式表。

export function links() {
  return [
    {
      rel: 'stylesheet',
      href: 'https://test.min.css',
    },
  ]
}

通过上述代码,会自动在页面中装载和卸载 link。

表单

Next.js 非内置,需要使用 ajax 处理。

Remix 提供了内置表单功能 通过

相关文章

AI绘画秀:人工智能开启艺术的未来

AI绘画秀:人工智能开启艺术的未来

  随着人工智能技术的不断发展,其应用领域也越来越广泛。在艺术领域中,人工智能也逐渐开始发挥出其独特的作用。AI绘画秀就是其中很引人注目的一种应用,它将人工智能与美术相结合,...

我们使用相同步骤,建立标签表,并且添加数据到表中。

建立表关联

题目表和标签表是多对一的关系,一个标签下有多道题目,一个题目只有一个标签

Notion 建立表关联

在题目表添加属性tag,选择 Relation,让后选择“标签”表

Notion 建立表关联

这样题目表和标签表就建立了关系

创建 Notion 集成

在使用 Notion API 之前,我们需要创建一个 Notion 的应用集成,获取 API Key。 打开 https://www.notion.so/my-integrations,打开 Notion 集成页面,登录自己的账号,点击 New integration 创建一个新的应用:

创建 Notion 集成

名称可以自己起,上传一个 LOGO,然后关联一个 Notion 的工作空间:

创建 Notion 集成,填写信息

点击提交,这个应用就创建好了,在跳转的新页面里,把Internal Integration Token复制下来,不要泄露,否则拿到这个 key 的人都能操作你的笔记啦。

复制 Notion Token

使用 Notion 数据库进行 Next.js 应用全栈开发

文章为稀土掘金技术社区首发签约文章,14 天内禁止转载,14 天后未获授权禁止转载,侵权必究!前言在上一篇中,我们使用了 strapi 和 Next.js 开发了一个简易微博,但是我没有部署上线,因为...

AI绘画:开启艺术与科技的新篇章

AI绘画:开启艺术与科技的新篇章

  近年来,随着人工智能技术的快速发展,越来越多的领域开始探索AI的应用。作为一门艺术,绘画也在逐渐被AI所渗透。AI绘画技术已经开始广泛应用在各种领域,如游戏、影视、虚拟现...

让智能技术释放你的创造力

让智能技术释放你的创造力

  AI绘画技术的日益普及,让人们越来越意识到它在创意设计、数字艺术等领域的潜力。如果你是一个创意工作者,或者想要学习数字艺术,那么学习AI绘画就成了必然的选择。在本文中,我们将介绍AI绘画的基础概念...

人工智能对生活的影响:改变未来,创造无限可能

人工智能对生活的影响:改变未来,创造无限可能

  人工智能(Artificial Intelligence,简称AI)作为一项前沿科技,正逐渐渗透到我们生活的方方面面。它的发展和应用给人类社会带来了巨大的变革,也改变...

百度AI人脸对比:现实应用与潜在影响

百度AI人脸对比:现实应用与潜在影响

  随着人工智能技术的快速发展,人脸识别技术已经成为各个领域广泛应用的一项重要技术。其中,百度AI人脸对比技术凭借其高精度和强大的功能,在社会治安、金融安全、智能门禁等领域发...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。