A test bed with sample projects using React in different ways.
Examples will include:
- CSR (Client Side Rendering)
- Think
create-react-app
or Vite'sreact-ts
template, which is what this example is based off of.
- Think
- Static SSR + SSG
- This example includes static server side rendering and static site generation with renderToStaticMarkup. This is kind of like Astro with SSG, if it used React components instead of Astro components and had no concept of client hydration directives.
- Static SSR + SSG with Hydration
- This example includes static server side rendering and static site generation with renderToStaticMarkup. This is kind of like how react-static worked (RIP), where it would render your site to static HTML so you could serve it in an S3 bucket without needing a server, and then hydrate the site on the client side.
- SSR (Server Side Rendering with renderToString and Hydration)
- This example includes server side rendering with renderToString and client side hydration with ReactDOM.hydrate. Think create-vite-extra's
template-ssr-react
template (which is what this example is based off of), or older versions of Remix.
- This example includes server side rendering with renderToString and client side hydration with ReactDOM.hydrate. Think create-vite-extra's
- Streaming SSR (Server Side Rendering with renderToPipeableStream and Hydration)
- This example includes server side rendering with renderToPipeableStream and client side hydration with ReactDOM.hydrate. Think newer versions of Remix. TODO: Figure out how to get Vite's dev mode working correctly, and setup Suspense-enabled data fetching so we can actually try Suspense properly.
- RSC (React Server Components) with CSR (TODO)
- RSC (React Server Components) with SSR and Hydration (TODO)