最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Blitz.js 一体化开发 (1.2):与 Next.js 进行权衡

    正文概述 掘金(hylerrix)   2021-03-25   825

    Next.js 是什么?

    Blitz 是基于 Next.js 的,因此几乎支持 Next.js 的所有功能。有关差异的更多信息,请参见此处:为什么是 Blitz 而非 Next.js。

    Next.js 是一个流行的 React 框架,其中有很多内置功能,例如:

    • 预渲染,每页支持静态生成 (SSG) 和服务端渲染 (SSR)。
    • 自动代码拆分,可更快地加载页面。
    • 客户端路由具有优化的预加载功能。
    • 开发环境支持热更新。
    • 完全可拓展。

    为什么是 Blitz 而非 Next.js?

    1. 全栈而非前端

    Next.js 主要是一个前端框架。它是为构建连接到其它 API 的前端而设计的。Nex.js 并不是一个真正的、开箱即用的全栈框架。

    Blitz 中添加了所有缺少的功能,这些功能使 Next 变成了真正的全栈框架。这些关键功能包括直接访问数据库,中间件和身份验证。

    2. 数据层

    Blitz 的数据层是一种新颖的技术,可以再保留客户端渲染的同时消除 API。在 Blitz 应用中,你可以将服务器代码直接导入前端,因此无需构建 API 并从前端进行数据提取工作。在构建时,Blitz 自动插入一个 API 调用,该 API 调用在服务器上运行服务端代码。本质上,Blitz 将你的 API 抽象为一个编译步骤。

    这是 React 应用程序开发的游戏规则改变者,因为它消除了传统 React 应用程序体系结构的整个部分。这意味着更容易学习、更快开发,并且构建事务更有趣!

    也就是说,你可以像往常一样继续通过 REST 或 GraphQL 进行数据获取。Blitz 对此没有任何限制。

    3. 内置身份验证

    Blitz 具有可与任何身份验证商一起使用的内置会话管理服务,包括自托管的电子邮件/密码和第三方服务。身份验证是一项复杂且难以正确实施的事情。将其内置到 Blitz 中可以为你节省大量时间和潜在的安全漏洞。

    在 Next.js 中使用 auth 构建令人敬畏的 UX 会非常地棘手和乏味,但是 Blitz 免费为你提供了一流的 DX。

    4. 约定

    除了基于文件系统的路由外,Next.js 没有任何约定。此时,每个开发人员都可以为每个项目重新发明轮子。

    Blitz 带来了许多约定,例如如何组织文件以及如何构造路由。这意味着你不会浪费任何时间为每个项目弄清楚这一点。这也极大地造福了社区。通用的项目结构和架构模式可让你从 Blitz 应用程序迁移到 Blitz 应用程序,并立即感到宾至如归。

    5. 代码脚手架

    有两种主要方法可以减少你必须手工编写的代码量:

    1. 代码生成
    2. 代码脚手架

    Code 生成 意味着让库来为你生成代码。例如,可以通过 GraphQL 查询生成代码的 graphql-code-generator 和可以从你的数据库架构中生成整个 GraphQL API 的 Hasura。通常,codegen 无法完全自定义生成的代码。你需要通过库来支持。同时你也会常遇到 codegen 无法解决的极端情况。而且你无法修复它,因为你不拥有该代码。

    Code 脚手架 意味着初始代码将注入到你的项目之中。从那时起,你对所有代码拥有着完全的所有权,并可以根据需要进行自定义。代码脚手架的缺点是你不会像从第三方库生成的代码那也获得自动更新。但巨大的好处在于其可以确保你永远不会受到别人无法改变的设计选择的限制。

    Blitz 是代码脚手架的忠实拥护者。我们有大量的 blitz generate 命令,可将代码脚手架插入你的项目中。我们的代码脚手架还处于初期阶段——我们仍然需要添加许多强大的功能,包括添加自己的自定义脚手架模板的功能。

    6. 配方

    Recipes 是用于将代码从 npm 或 git 存储库上的 MDX 配方放入你的项目中的单行命令。

    例如:

    • blitz install tailwind——一行命令安装和配置 tailwind
    • blitz install chakra-ui——一行命令安装和配置 chakra
    • blitz install material-ui——一行命令安装和配置 material-ui

    Recipes 超级强大,它们几乎可以更改项目中的任何内容,包括添加依赖项、更改代码、添加代码等。它们是通过 MDX 编写的,可以像 React 一样组成。

    7. 全新的开发环境

    一个新的 Next.js 应用是完全恐怖的。因此,每次你启动 Next.js 项目,你必须花费数小时来建立 eslint、petterier、husky git hooks 等的所有基础知识。

    一个新的 Blitz 应用可以为你节省大量时间,因为所有这些都是为你预先配置的!当然,你以后始终可以对其进行自定义,但是拥有一个可行的起点真的很棒。

    8. 放宽限制

    Next.js 要求你所有的 React 页面都放在一个 pages/ 文件夹中。Blitz 通过允许你拥有无限数量的 pages/文件夹来放宽此限制。

    对于大型项目,这是一个巨大的好处,因为你可以按任意方式分离和组织页面。

    例如:

    • app/pages/ 可以包含“首页”和“关于”之类的页面
    • app/products/pages/ 可以包含于产品相关的所有页面
    • app/admin/pages/ 可以包含与后端 admin 部分相关的所有页面

    权衡

    你应该会知道,一切都需要被权衡。那么 Blitz 需要权衡的是什么?

    框架限制

    每个框架都有一定程度的限制。如果你使用 React 构建应用,那么就很容易被 React 限制。

    Blitz 的限制级别比 Next.js 高一个级别。Blitz 代码库与 Next.js 代码库没有 太多 不同。但这已经够不同了,以至于“弹出”到普通的 Next.js 并不简单。例如,你可能将使用 Blitz 所特有的 Blitz 身份验证。但切换到 Next AUth 将为你提供与 Next.js 相当的体验。

    Blitz 零 API 数据层是 Blitz 独有的。因此,如果此时切换到 Next.js,则必须管理自己的 API 代码(而如果从 Next.js 开始,则必须这么做,因此不会丢失任何内容)。但是,你所有的后端 query 和 mutation 逻辑都可以直接移植。

    升级 Next.js

    如果你想站在 Next.js 版本的最前沿,请知道 Blitz 会稍微落后但不会太远。通常,我们会在新的 Next.js 版本发布后不到一周的时间内更新 Blitz。

    但如果你使用 yarn,则可以先使用 package.json 中的 resolutions 字段来升级 next.js。

    多客户端 API

    有人会说,“迟早你会需要 GraphQL,所以你应该从它开始”。虽然我们认为绝大多数应用程序的增长不会足够大以至于不能保证 GraphQL,但是提供多个客户端的 API 的问题是一个很好的要点。

    我们完全承认,许多 Web 应用程序迟早都需要移动应用程序。我们希望这种集成尽可能的简单!

    也就是说,你可以为其他客户端将 GraphQL 服务器添加到 Blitz 应用中,这可能是一个很好的选择,有些人已经开始这样做了。

    目前,截至 2021 年 2 月 17 日:

    • 你可以直接访问自动生成的 API 接口,并且可以在任何移动应用中使用它们(我们目前有几个人在建设中);
    • 你可以通过 blitz routes 来查看应用程序中生成的 API;
    • 你可以在此处查看 API 接口的 RPC 规范:RPC Specification。

    我们计划今后要做的事:

    1. 第一步,添加文档和工具,以使手动使用生成的 API 接口变得更加容易,访问:github.com/blitz-js/bl… 和 github.com/blitz-js/bl…;
    2. 接下来,添加生成一个 JS/TS 客户端库的功能,作为使用从应用生成接口的好方

    法;

    1. 还有,添加某种一流的 react-native 支持,你可以再其中将 Blitz queries/mutations 直接导入到你的 react-native 代码中,并使它神奇地工作,就像今天在你的 Web 应用程序中一样。在 1.0 版本后,这将是 Brandon 在这一年中的主要工作重点。

    高阶后端架构

    目前,Blitz 在后端架构上的功能还很少,尤其是与 Nest.js 或 AdonisJS 之类的 东西相比。但是,这并不意味着你不能在 Blitz 中使用这些模式,但你需要自己进 行设置。实际上,如果需要,你可以在 Blitz 应用中直接使用 Nest.js。

    但是我们非常有兴趣通过默认支持或简单的植入来加入更先进的后端体系架构到 Blitz 中。我们有一个正在进行的讨论,如果你有想法,我们希望你能加入。

    当不部署到 Serverless 时的单线程

    具体来说,这是 Next.js 的折衷方案。Next.js 是单线程的,这意味着如果你在进行繁重的后端处理时,你可能会发现所有的 Web 请求都开始受到影响。解决方案是让后端处理来生成其他进程。

    运行多个后台进程并不是很困难,但是我们希望添加文档和 API,以使其尽可能简单。

    译者结语

    本文内容属于 Blitz.js 官方文档 - 简介章节的后半部分。总共十四个章节(简介、社区、基础、页面、路由、权限、数据库、Queries 和 Mutations、后端架构、部署、配方、配置、CLI 和模板)。未来不定期翻译其余章节,也可能会原创一些文章。

    《React 全栈开发手册》系列专注探索 Blitz.js + React 全栈应用开发,原文翻译内容会同步更新到 Blitz.js 中文仓库 上。欢迎 Star、Watch 或关注公众号 (@ningowood) 来及时接收消息。


    起源地下载网 » Blitz.js 一体化开发 (1.2):与 Next.js 进行权衡

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元