Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

渐进式 JSON

Posted on 2025-06-01

渐进式 JSON

Dan Abramov 的这篇文章是个陷阱!它提出了一种巧妙的方法,将 JSON 对象以流式传输的方式传输到客户端,在传输完成之前提供 JSON 的结构,然后在更多数据到达时填补空白……结果却变成了一个 React 服务器组件工作原理的隐秘教程。

忽略其隐秘性,它所描述的假想流式 JSON 格式是一个有趣的思维练习:

 { header: "$1", post: "$2", footer: "$3" } /* $1 */ "Welcome to my blog" /* $3 */ "Hope you like it" /* $2 */ { content: "$4", comments: "$5" } /* $4 */ "This is my article" /* $5 */ ["$6", "$7", "$8"] /* $6 */ "This is the first comment" /* $7 */ "This is the second comment" /* $8 */ "This is the third comment"

在每个块之后,可以构建到目前为止的完整 JSON 文档,并且 Dan 建议沿途交错Promise()对象,用于尚未完全解析的占位符 – 因此在收到上面的块$3之后(请注意,块可以无序提供)文档将如下所示:

 { header: "Welcome to my blog", post: new Promise(/* ... not yet resolved ... */), footer: "Hope you like it" }

我暂时保留这个想法,以便将来有机会尝试它。

标签: json 、 react 、 javascript

原文: https://simonwillison.net/2025/Jun/1/progressive-json/#atom-everything

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Bits about Money
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • Elad Gil
  • Ellie Huxtable
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • Henrique Dias
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mostly metrics
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme