A full-featured Webpack 4 setup with hot-reload, lint-on-save, unit testing, css extraction & pug support.
This template is Vue 2.0 compatible.
Fastify server.
Ready for Heroku
Original branch: noamkfir/webpack
- For this template: common questions specific to this template are answered and each part is described in greater detail
- For Vue 2.0: general information about how to work with Vue, not specific to this template
This is a project template for @vue/cli. @vue/cli require Node.js 8 or above (8.10.0+ recommended)
$ npm install -g @vue/cli @vue/cli-init
$ vue init trevonerd/vue-webpack4-pug-fastify my-project
$ cd my-project
$ npm install
$ npm run devThis will scaffold the project using the master branch. If you wish to use the latest version of the webpack template, do the following instead:
$ vue init trevonerd/vue-webpack4-pug-fastify#develop my-projectThe development server will run on port 8080 by default. If that port is already in use on your machine, the next free port will be used.
-
npm run dev: first-in-class development experience.- Webpack +
vue-loaderfor single file Vue components. - State preserving hot-reload
- State preserving compilation error overlay
- Lint-on-save with ESLint
- Source maps
- Webpack +
-
npm run build: Production ready build.- JavaScript minified with UglifyJS v3.
- HTML minified with html-minifier.
- CSS across all components extracted into a single file and minified with cssnano.
- Static assets compiled with version hashes for efficient long-term caching, and an auto-generated production
index.htmlwith proper URLs to these generated assets. - Use
npm run build --reportto build with bundle size analytics.
-
npm run prod: lunch fastify server.- Logging with Pino
- Servs static files
- gzip compression
-
npm run unit: Unit tests run in JSDOM with Jest, or in PhantomJS with Karma + Mocha + karma-webpack.- Supports ES2015+ in test files.
- Easy mocking.
-
npm run e2e: End-to-end tests with Nightwatch.- Run tests in multiple browsers in parallel.
- Works with one command out of the box:
- Selenium and chromedriver dependencies automatically handled.
- Automatically spawns the Selenium server.
You can fork this repo to create your own boilerplate, and use it with vue-cli:
vue init username/repo my-project