做項目過程中,需要用到后臺模擬數(shù)據(jù),在機緣巧合下發(fā)現(xiàn)了mock,在學(xué)習(xí)使用的過程中又偶遇了axios-mock-adapter?,F(xiàn)在將實例展示如下:
在蟠龍等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站設(shè)計、網(wǎng)站制作 網(wǎng)站設(shè)計制作按需網(wǎng)站開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),全網(wǎng)整合營銷推廣,外貿(mào)網(wǎng)站建設(shè),蟠龍網(wǎng)站建設(shè)費用合理。
1、準(zhǔn)備
實例是建立在vue-cli的基礎(chǔ)上實現(xiàn)
需要提前安裝的插件有:
axios:npm install axio --save
mockjs:npm install mockjd --save-dev
axios-mock-adapter:npm install axios-mock-adapter --save-dev
引入
第一種引入方式:按照es6的語法,以import的方式引入
import axios from 'axios'; import MockAdapter from 'axios-mock-adapter';
第二種引入方式:以require方式引入
var axios = require('axios'); var MockAdapter = require('axios-mock-adapter');
代碼實例
整個項目的代碼結(jié)構(gòu)如下:
首先新建一個login.vue文件,代碼如下
Login
記住密碼 login reset
由于路由的默認指向是HelloWorld,所以修改router文件夾下的index.js
import Vue from 'vue' import Router from 'vue-router' // 懶加載方式,當(dāng)路由被訪問的時候才加載對應(yīng)組件 const Login = resolve => require(['@/components/Login'], resolve) Vue.use(Router) export default new Router({ routes: [{ path: '/', name: 'login', component: Login }]
此時登錄界面樣式基本寫好,接下來修改main.js,將需要引入的文件引入
如下:
import Vue from 'vue' import App from './App' import router from './router' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' import axios from 'axios' Vue.prototype.$ajax = axios // axios不能直接使用use引入,只能每個需要發(fā)送請求的組件中即時引入,兩種引入方式 // 第一種引入方式:引入axios后,修改原型鏈 // import axios from 'axios' // Vue.prototype.$axios = axios Vue.config.productionTip = false; Vue.use(ElementUI); /* eslint-disable no-new */ new Vue({ el: '#app', router, store, // 使用store components: { App }, template: '' })
刷新頁面
接下來就是對login.vue頁面進行改造:增加登錄點擊事件和重置事件
login reset
此時的點擊事件沒有交互功能,使用axios和mock.js實現(xiàn)交互,并且使用axios-mock-adapter進行axios數(shù)據(jù)調(diào)試
在src下新建一個axios文件夾,并建一個api.js
import axios from 'axios' axios.defaults.baseURL = 'http://127.0.0.1:80'; export const requseLogin = params => { return axios.post('/user/login', params); }
再新建一個index.js
import * as api from './api' export default api
這是像后臺發(fā)起post請求,地址是‘user/login'
此處的后臺數(shù)據(jù)我們使用mockjs進行攔截,然后模擬后臺服務(wù)返回的數(shù)據(jù)
創(chuàng)建mock后臺模擬數(shù)據(jù)
在src目錄下創(chuàng)建mock文件夾,并且新建一個index.js,index.js內(nèi)容如下:、
// 通過axios-mock-adapter生成代理api地址 import axios from 'axios' import MockAdapter from 'axios-mock-adapter' // import { LoginUsers } from './data/user' import {users} from './data/user' export default { init() { let mock = new MockAdapter(axios); // mock success request 模擬成功請求 mock.onGet('/success').reply(200, { msg: 'success' }); // mock error request 模擬失敗請求 mock.onGet('/error').reply(500, { msg: 'failure' }) // login 模擬登錄接口 mock.onPost('/user/login').reply(config => { // 解析axios傳過來的數(shù)據(jù) let { username, password } = JSON.parse(config.data); return new Promise((resolve, reject) => { // 先創(chuàng)建一個用戶為空對象 let user = null; setTimeout(() => { // 判斷模擬的假數(shù)據(jù)中是否有和傳過來的數(shù)據(jù)匹配的 let hasUser = users.some(person => { // 如果存在這樣的數(shù)據(jù) if (person.username === username && person.password === password) { user = JSON.parse(JSON.stringify(person)); user.password = undefined; return true; }else { // 如果沒有這個person return false } }); // 如果有那么一個人 if (hasUser) { resolve([ 200, {code: 200, msg: '登錄成功',user} ]); } else { // 如果沒有這么一個人 resolve([ 200, {code: 500, msg: '賬號錯誤' }]) } }, 500); }) }); // 模擬注冊接口 } }
接著在mock下建立data文件夾,;里面新建user.js用來存放用戶信息
/* * 用來存放一些模擬用戶的數(shù)據(jù) * */ // import Mock from 'mockjs' const users = [ { id: 1, username: 'admin', password: '123456', email: '123456@qq.com', name: '搬磚者' }, { id: 2, username: 'lytton', password: '123456', email: 'yyyyy@163.com', name: '混子' } ] export { users }
為login.vue文件增加登錄方法
當(dāng)點擊登錄按鈕后,跳轉(zhuǎn)到‘/home'頁面,在components文件夾下面新增home.vue文件
{{ msg }}
接下了修改router中的index.js
import Vue from 'vue' import Router from 'vue-router' // import HelloWorld from '@/components/HelloWorld' // import Home from '../components/home'; // 懶加載方式,當(dāng)路由被訪問的時候才加載對應(yīng)組件 const Login = resolve => require(['@/components/Login'], resolve) const Home = resolve => require(['@/components/home'], resolve) Vue.use(Router) const router = new Router({ routes: [ { path: '/', name: 'login', component: Login }, { path: '/login', name: 'login', component: Login }, { path: '/home', name: 'home', component: Home } ] }) // 訪問之前,檢查是否登陸了 router.beforeEach((to, from, next) => { if(to.path.startsWith('/login')) { window.sessionStorage.removeItem('user'); next() }else { let token = window.sessionStorage.getItem('user'); if (!token) { next({path: '/login'}) }else { next() } } }); export default router
在main.js中引入mock
import Vue from 'vue' import Router from 'vue-router' // import HelloWorld from '@/components/HelloWorld' // import Home from '../components/home'; // 懶加載方式,當(dāng)路由被訪問的時候才加載對應(yīng)組件 const Login = resolve => require(['@/components/Login'], resolve) const Home = resolve => require(['@/components/home'], resolve) Vue.use(Router) const router = new Router({ routes: [ { path: '/', name: 'login', component: Login }, { path: '/login', name: 'login', component: Login }, { path: '/home', name: 'home', component: Home } ] }) // 訪問之前,檢查是否登陸了 router.beforeEach((to, from, next) => { if(to.path.startsWith('/login')) { window.sessionStorage.removeItem('user'); next() }else { let token = window.sessionStorage.getItem('user'); if (!token) { next({path: '/login'}) }else { next() } } }); export default router
至此,運行npm run dev即可
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。