vue也弄了一段時間了, 前段時間一直想用vue寫個移動端,加之年末也不是很忙,因而前幾天便着手開始弄了,到今天爲止也算是勉強能看了html
由於也是純粹的寫寫前端頁面,因此數據方面用的是mock.js,爲了真實的模擬請求,能夠直接在 Easy Mock 本身生成API
也可直接登錄我這項目的Easy Mock帳號密碼:前端
帳號: vue-toutiao
密碼: 123456vue
若是你想修改接口,請copy一份在修改webpack
若是你想後臺接口也本身開發的話。能夠閱讀我這篇博客 Vue + Node + Mongodb 開發一個完整博客流程ios
vue
+ webpack
+ vuex
+ axios
git
assets
: 靜態資源文件,存放圖片啥的components
: 經常使用組件封裝directive
: 經常使用指令封裝router
: 路由表store
: 狀態管理 vuexstyles
: 樣式文件utils
: 經常使用工具類封裝views
: 視圖頁面此項目用到了 DllPlugin 進行打包處理,全部啓動該項目時記得,先執行一次該腳本命令生成配置github
{ path: '/development', name: 'development', component: (resolve) => { require(['../views/development.vue'], resolve) } }
或web
const _import_ = file => () => import('views/' + file + '.vue') { path: '/development', name: 'development', component: _import_('development') }
經過路由的 beforeEach 鉤子函數來判斷是否須要登錄vuex
// 如:系統設置須要登錄 { path: '/system', name: '系統設置', meta: { login: true }, component: _import_('System/index') } router.beforeEach((to, from, next) => { if (to.meta.login) { //判斷前往的界面是否須要登錄 if (store.state.user.user.name) { // 是否已經登錄 next() }else{ Vue.prototype.$alert('請先登陸!') .then( () => { store.state.user.isLogin = true }) } }else{ if (to.meta.page) store.state.app.pageLoading = true next() } })
經過檢測設置在 Router上的animate屬性 來判斷它作什麼樣的切換動畫chrome
Router.prototype.animate = 0 // 獲取每一個路由meta上面的slide 來判斷它作什麼動畫 { path: '/system', name: '系統設置', meta: { slide: 1 }, component: _import_('System/index') } watch: { $route (to, from) { /* 0: 不作動畫 1: 左切換 2: 右切換 3: 上切換 4: 下切換 ... */ let animate = this.$router.animate || to.meta.slide if (!animate) { this.animate = '' }else{ this.animate = animate === 1 ? 'slide-left' : animate === 2 ? 'slide-right' : animate === 3 ? 'slide-top' : animate === 4 ? 'slide-bottom' : '' } this.$router.animate = 0 } }
一些更加詳細的配置可在github上查看
github地址
博客地址