Server side rendering for react.js applications
Site
Server side rendering for react.js applications.
Installation
npm install @borderless/site --save-dev
Features
- Server-side rendering with getServerSideProps
- Client-side hydration for interactivity
- Custom <Head />rendering with@borderless/site/head
- Hot reloading and react refresh during development
- Super fast server with Vite
- ES Modules supported
Usage
Commands:
- devRun a local development server with HMR
- buildGenerate client and server-side compatible bundles
- listList the pages in your SSR app
Options:
- --rootProject root directory (default:- process.cwd())
- --srcDirectory to read source files (default:- src)
- --public-dirDirectory to serve as plain static assets (default:- public)
Dev
Run a local development server with hot reload support
Options:
- --portSpecify the port to run on (default:- 8000)
Build
Build client and server-side bundles for deploying to a production environment.
Options:
- --baseBase public path when built in production (default:- /)
- --out-clientOutput directory for client files relative to root (default:- dist/client)
- --out-clientOutput directory for server files relative to root (default:- dist/server)
- --source-mapGenerate production source maps (default:- false)
List
Lists the files used to build the project. The pages are all in root and follow the patterns of _app, _404, _document, _error, or pages/**/index. Acceptable extensions are .ts, .tsx, .js, and .jsx.
Development
Useful scripts are in package.json under scripts. You can build, test, and format the project. Additionally you can run examples locally using ts-node:
npm run example:test -- dev
Inspiration
TypeScript
This project is written using TypeScript and publishes the definitions directly to NPM.