First Load JS of 76Kb. This starter will automatically pick the marked R3F components and inject them into a canvas layout so we can navigate seamlessly between the pages with some dynamic dom and canvas content without reloading or creating a new canvas every time.
Tailwind is the default and only stable
yarn create r3f-app next my-app
or
npx create-r3f-app next my-app
- Automatically inject r3f component in the Canvas
- Support glsl imports
- PWA Support
- Layout for Canvas and DOM
- Template for the meta data and header
- Clean code using ESlint and Prettier
- Use esbuild in development for faster HMR
- VSCode debug profiles for the server, Chrome, and Firefox
Inform the nextjs page that the component is a Threejs component. For that, simply add the r3f property to the parent component.
const Page = () => {
return (
<>
<div>Hello !</div>
{/* Simply add the r3f prop to the parent component -> */}
<MeshComponent r3f />
</>
)
}
export default Page
const Page = () => {
return (
// even if there is only 1 element add an empty parent to the page component ->
<>
{/* If your page doesn't have any 3D and you don't want to render the canvas to improve performances -> */}
<div noCanvas>Hello !</div>
</>
)
}
export default Page
yarn dev
- Next devyarn analyze
- Generate bundle-analyzeryarn lint
- Audit code qualityyarn build
- Next buildyarn start
- Next startyarn export
- Export to static HTML
threejs
– A lightweight, 3D library with a default WebGL renderer.@react-three/fiber
– A React renderer for Threejs on the web and react-native.@react-three/drei
– useful helpers for react-three-fiber@react-three/a11y
– Accessibility tools for React Three Fibertailwind
– A utility-first CSS framework packed with classes like flex, pt-4, text-center and rotate-90 directly in your markup.r3f-perf
- Optional – Tool to easily monitor react threejs performances.
git clone https://github.com/pmndrs/react-three-next
&& cd react-three-next && yarn install