# Vue2-SPA > 可能是全网最干净的 `vue` 仓库 > A Vue.js project with axios/vue-router/webpack ## Live Demo The live demo can be found in [https://allan2coder.github.io/VUE2-SPA-Tutorial/](https://allan2coder.github.io/VUE2-SPA-Tutorial/) (移动端,打开浏览器开发者工具并调到手机窗口浏览。注:该项目同时适合PC端) ## How to use You should clone the repo and install the dependencies, and then npm start.That is all. ```bash $ git clone https://github.com/allan2coder/VUE2-SPA-Tutorial.git $ cd VUE2-SPA-Tutorial $ npm install ``` Then launch the project app. ```bash $ npm start ``` You should see a new browser tap opening and a page of 'index.html' in http://localhost:8080. ## How to build the static files ``` bash npm run build ``` ## [Lifecycle](https://cn.vuejs.org/v2/guide/instance.html#%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F%E5%9B%BE%E7%A4%BA) ![image](https://cn.vuejs.org/images/lifecycle.png) ## Router HTML ``` bash import Vue from 'vue' import VueRouter from 'vue-router' or

Go to Foo Go to Bar

``` JavaScript ``` bash // 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 vue.use(vuerouter) // 1. 定义(路由)组件。 // 可以从其他文件 import 进来 const Foo = { template: '
foo
' } const Bar = { template: '
bar
' } // 2. 定义路由 // 每个路由应该映射一个组件。 其中"component" 可以是 // 通过 Vue.extend() 创建的组件构造器, // 或者,只是一个组件配置对象。 const routes = [ { path: '/foo', component: Foo }, { path: '/bar', component: Bar } ] // 3. 创建 router 实例,然后传 `routes` 配置 // 你还可以传别的配置参数, 不过先这么简单着吧。 const router = new VueRouter({ routes // (缩写)相当于 routes: routes }) // 4. 创建和挂载根实例。 // 记得要通过 router 配置参数注入路由, // 从而让整个应用都有路由功能 const app = new Vue({ router }).$mount('#app') // 现在,应用已经启动了! ``` ### 有关打包优化 第三方库单独打包 ``` npm i autodll-webpack-plugin -D ``` webpack 配置: ``` new AutoDllPlugin({ inject: true, // will inject the DLL bundle to index.html debug: true, filename: '[name]_[hash].js', path: './dll', entry: { vendor: ['vue', 'vue-router'] // webpack 会去 `node_modules` 去找 } }) ``` 每次打包,这个插件都会检查注册在 `entry` 中的第三方库。如果没有变化,插件就会使用缓存中的打包文件,减少了打包的时间,这时 Hash 也不会变化。 ## Other SPA(其他单页) - [React.js 2.x](https://github.com/allan2coder/React-SPA) :fire: :fire: :fire: - [Angularjs 2.x](https://github.com/allan2coder/Angular2-SPA) # Reference Articles * [Vue-Router](http://router.vuejs.org/zh-cn/essentials/getting-started.html) * [ECMAScript 6入门](http://es6.ruanyifeng.com/) * [Webpack 入门指迷](https://segmentfault.com/a/1190000002551952) * [webpack使用优化](https://github.com/lcxfs1991/blog/issues/2) * [vue guide](http://vuejs-templates.github.io/webpack/) * [docs for vue-loader](http://vuejs.github.io/vue-loader)