提供完整的路由,services`````````````
站在用戶的角度思考問題,與客戶深入溝通,找到小店網站設計與小店網站推廣的解決方案,憑借多年的經驗,讓設計與互聯(lián)網技術結合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網站制作、做網站、企業(yè)官網、英文網站、手機端網站、網站推廣、國際域名空間、網站空間、企業(yè)郵箱。業(yè)務覆蓋小店地區(qū)。
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
index.html
insurance-weixin
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
main.js
import Vue from 'vue' import Vuex from 'vuex' import VueRouter from 'vue-router' import FastClick from 'fastclick' import {WechatPlugin, AjaxPlugin, LoadingPlugin, ToastPlugin, AlertPlugin} from 'vux' import App from './app.vue' /** * 加載插件 */ Vue.use(Vuex) Vue.use(VueRouter) Vue.use(WechatPlugin) Vue.use(AjaxPlugin) Vue.use(LoadingPlugin) Vue.use(ToastPlugin) Vue.use(AlertPlugin) /** * 定義常量 */ const domainName = 'localhost:8010' const serverName = 'localhost:3000' const apiPrefix = serverName + '/api/outer' const loginTimeOutErrorCode = 'login_timeout_error' /** * 設置vuex */ const store = new Vuex.Store({}) store.registerModule('vux', { state: { loading: false, showBack: true, title: '' }, mutations: { updateLoading (state, loading) { state.loading = loading }, updateShowBack (state, showBack) { state.showBack = showBack }, updateTitle (state, title) { state.title = title } } }) /** * 設置路由 */ const routes = [ // 初始頁 { path: '/', component: function (resolve) { require(['./components/init.vue'], resolve) } }, // 主頁 { path: '/index', component: function (resolve) { require(['./components/index.vue'], resolve) }, children: [ // 測試頁 { path: 'test', component: function (resolve) { require(['./components/tests/page.vue'], resolve) } } ] }, // 綁定頁 { path: '/bind', component: function (resolve) { require(['./components/bind.vue'], resolve) } } ] const router = new VueRouter({ routes }) router.beforeEach(function (to, from, next) { store.commit('updateLoading', true) store.commit('updateShowBack', true) next() }) router.afterEach(function (to) { store.commit('updateLoading', false) }) /** * 點擊延遲 */ FastClick.attach(document.body) /** * 日志輸出開關 */ Vue.config.productionTip = true /** * 定義全局公用常量 */ Vue.prototype.domainName = domainName Vue.prototype.serverName = serverName Vue.prototype.apiPrefix = apiPrefix /** * 定義全局公用方法 */ Vue.prototype.http = function (opts) { let vue = this vue.$vux.loading.show({ text: 'Loading' }) vue.$http({ method: opts.method, url: apiPrefix + opts.url, headers: opts.headers || {}, params: opts.params || {}, data: opts.data || {} }).then(function (response) { vue.$vux.loading.hide() opts.success(response.data.data) }).catch(function (error) { vue.$vux.loading.hide() if (!opts.error) { let response = error.response let errorMessage = '請求失敗' if (response && response.data) { if (response.data.code === loginTimeOutErrorCode) { window.location.href = '/' } errorMessage = response.data.message } vue.$vux.alert.show({ title: '提示', content: errorMessage }) } else { opts.error(error.response.data.data) } }) } Vue.prototype.get = function (opts) { opts.method = 'get' this.http(opts) } Vue.prototype.post = function (opts) { opts.method = 'post' this.http(opts) } Vue.prototype.put = function (opts) { opts.method = 'put' this.http(opts) } Vue.prototype.delete = function (opts) { opts.method = 'delete' this.http(opts) } Vue.prototype.valid = function (opts) { let vue = this let valid = true if (opts.ref && !opts.ref.valid) { valid = false } if (opts.ignoreRefs) { let newRefs = [] for (let i in opts.refs) { let ref = opts.refs[i] for (let j in opts.ignoreRefs) { let ignoreRef = opts.ignoreRefs[j] if (ref !== ignoreRef) { newRefs.push(ref) } } } opts.refs = newRefs } for (let i in opts.refs) { if (!opts.refs[i].valid) { valid = false break } } if (valid) { opts.success() } else if (opts.error) { opts.error() } else { vue.$vux.toast.show({ text: '請檢查輸入' }) } } Vue.prototype.closeShowBack = function () { this.$store.commit('updateShowBack', false) } Vue.prototype.updateTitle = function (value) { this.$store.commit('updateTitle', value) } /** * 創(chuàng)建實例 */ new Vue({ store, router, render: h => h(App) }).$mount('#app-box') app.vuecomponents/index.vue components/tests/page.vueplaceholder {{i}}
components/tests/page.vue代碼中的 import Page from '../kits/page.vue'是我自己寫的下拉刷新上啦加在的組件,運行的話刪掉這些引用就可以了。
本次記錄摘要是從剛剛完成的項目中抽離的部分代碼(注:本項目實踐代碼,可運行,可運行,可運行,可運行)
總結
以上所述是小編給大家介紹的Vue+Vux項目實踐完整代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網站的支持!