-
Progressive Web App with Vuejs running on KoaJS (alternative to express) with HTTP/2
-
It supports server side render
-
This template is inspired by https://github.com/OrangeXC/n2ex
-
A full-featured Webpack setup with hot-reload, lint-on-save, unit testing & css extraction.
-
This template is Vue 2.0 compatible
- 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. It is recommended to use npm 3+ for a more efficient dependency tree.
$ npm install -g vue-cli
$ vue init workevolve/pwa-nuxt-koa-http2 my-project
$ cd my-project
$ npm install
$ npm run dev
Development runs on two servers serving http on default port 80 and https on default port 443. You can the default port to your desire port in setting defined in ./server/index.js
- http2 implementation is inspired by blog http://ivanjov.com/running-express-koa-and-hapi-on-http-2 and
- Example can be found here https://github.com/IvanJov/node-on-http2
-
npm run dev
: first-in-class development experience.- Webpack +
vue-loader
for 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.
- 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.html
with proper URLs to these generated assets. - Use
npm run build --report
to build with bundle size analytics.
-
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