A modern boilerplate for three.js projects 🎉
I whipped this up as a convenient starting point that will make three.js and shader development easier. Clone and you're ready to go with webpack, babel, GLSLify, a hot reloading dev server and a basic three.js scene including some extremely basic GLSLified shaders.
I find it easist to create new projects based on this repo with a little shell script. If you drop this in your .bashrc
or similar, you'll be good to go.
alias NewThreeProject="git clone git@github.com:elifitch/three-boilerplate.git && rm -rf ./three-boilerplate/.git && mv ./three-boilerplate "
$ NewThreeProject my-project-name
If you like to have three.js projects in a monorepo, you can do the same thing in an NPM script.
"new-project": "git clone git@github.com:elifitch/three-boilerplate.git && rm -rf ./three-boilerplate/.git && mv ./three-boilerplate "
$ npm run new-project my-project-name
npm run start
=> fires up the dev server and watches files for changesnpm run build
=> normal build with babel and all thatnpm run build-simple
=> includes three.js from cdnjs, doesn't transpile. Great for Codepen.
Three.js includes a lot of helpful modules in an examples/
directory. These are aliased in our webpack config so you don't have to import them via the full path in every file. You can add to or modify these aliases in /webpack/three-modules.config.js
.
There are a few environment variables you can use to change the build process
ASSET_ENV="http://my-asset-domain.com/" npm run build
=> Sets webpack publicPath.ROOT_RESOURCES=true npm run build
=> Outputs 3d models at the root of/dist
instead of in a folder. This will make sure your code references resources at eactlypuplicPath/fileUrl
, instead ofpublicPath/someFolder/fileUrl
which might give you a 404. Super useful when using codepen asset management.
- Three.js
- GLSLify for easy shader development
- Support for obj/mtl loading
- GSAP for easy animation
- Babel for nice ES6+ stuff
- Builds with webpack
- Hot reloading dev server
- Turn it into a CLI since that's a thing people do now I guess