摘要:做項(xiàng)目過(guò)程中,需要用到后臺(tái)模擬數(shù)據(jù),在機(jī)緣巧合下發(fā)現(xiàn)了,在學(xué)習(xí)使用的過(guò)程中又偶遇了。
做項(xiàng)目過(guò)程中,需要用到后臺(tái)模擬數(shù)據(jù),在機(jī)緣巧合下發(fā)現(xiàn)了mock,在學(xué)習(xí)使用的過(guò)程中又偶遇了axios-mock-adapter。現(xiàn)在將實(shí)例展示如下:
準(zhǔn)備
實(shí)例是建立在vue-cli的基礎(chǔ)上實(shí)現(xiàn)
需要提前安裝的插件有:
axios:npm install axio --save
mockjs:npm install mockjd --save-dev
axios-mock-adapter:npm install axios-mock-adapter --save-dev
引入
第一種引入方式:按照es6的語(yǔ)法,以import的方式引入
import axios from "axios";
import MockAdapter from "axios-mock-adapter";
第二種引入方式:以require方式引入
var axios = require("axios");
var MockAdapter = require("axios-mock-adapter");
代碼實(shí)例
整個(gè)項(xiàng)目的代碼結(jié)構(gòu)如下:
首先新建一個(gè)login.vue文件,代碼如下
Login
記住密碼 login reset
由于路由的默認(rèn)指向是HelloWorld,所以修改router文件夾下的index.js
import Vue from "vue" import Router from "vue-router" // 懶加載方式,當(dāng)路由被訪(fǎng)問(wèn)的時(shí)候才加載對(duì)應(yīng)組件 const Login = resolve => require(["@/components/Login"], resolve) Vue.use(Router) export default new Router({ routes: [{ path: "/", name: "login", component: Login }]
此時(shí)登錄界面樣式基本寫(xiě)好,接下來(lái)修改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引入,只能每個(gè)需要發(fā)送請(qǐng)求的組件中即時(shí)引入,兩種引入方式 // 第一種引入方式:引入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: "" })
刷新頁(yè)面
接下來(lái)就是對(duì)login.vue頁(yè)面進(jìn)行改造:增加登錄點(diǎn)擊事件和重置事件
login reset
此時(shí)的點(diǎn)擊事件沒(méi)有交互功能,使用axios和mock.js實(shí)現(xiàn)交互,并且使用axios-mock-adapter進(jìn)行axios數(shù)據(jù)調(diào)試
在src下新建一個(gè)axios文件夾,并建一個(gè)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); }
再新建一個(gè)index.js
import * as api from "./api" export default api
這是像后臺(tái)發(fā)起post請(qǐng)求,地址是‘user/login’
此處的后臺(tái)數(shù)據(jù)我們使用mockjs進(jìn)行攔截,然后模擬后臺(tái)服務(wù)返回的數(shù)據(jù)
創(chuàng)建mock后臺(tái)模擬數(shù)據(jù)
在src目錄下創(chuàng)建mock文件夾,并且新建一個(gè)index.js,index.js內(nèi)容如下:、
// 通過(guò)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 模擬成功請(qǐng)求 mock.onGet("/success").reply(200, { msg: "success" }); // mock error request 模擬失敗請(qǐng)求 mock.onGet("/error").reply(500, { msg: "failure" }) // login 模擬登錄接口 mock.onPost("/user/login").reply(config => { // 解析axios傳過(guò)來(lái)的數(shù)據(jù) let { username, password } = JSON.parse(config.data); return new Promise((resolve, reject) => { // 先創(chuàng)建一個(gè)用戶(hù)為空對(duì)象 let user = null; setTimeout(() => { // 判斷模擬的假數(shù)據(jù)中是否有和傳過(guò)來(lái)的數(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 { // 如果沒(méi)有這個(gè)person return false } }); // 如果有那么一個(gè)人 if (hasUser) { resolve([ 200, {code: 200, msg: "登錄成功",user} ]); } else { // 如果沒(méi)有這么一個(gè)人 resolve([ 200, {code: 500, msg: "賬號(hào)錯(cuò)誤" }]) } }, 500); }) }); // 模擬注冊(cè)接口 } }
接著在mock下建立data文件夾,;里面新建user.js用來(lái)存放用戶(hù)信息
/* * 用來(lái)存放一些模擬用戶(hù)的數(shù)據(jù) * */ // import Mock from "mockjs" const users = [ { id: 1, username: "admin", password: "123456", email: "[email protected]", name: "搬磚者" }, { id: 2, username: "lytton", password: "123456", email: "[email protected]", name: "混子" } ] export { users }
為login.vue文件增加登錄方法
當(dāng)點(diǎn)擊登錄按鈕后,跳轉(zhuǎn)到‘/home’頁(yè)面,在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)路由被訪(fǎng)問(wèn)的時(shí)候才加載對(duì)應(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 } ] }) // 訪(fǎng)問(wèn)之前,檢查是否登陸了 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 App from "./App" import router from "./router" //創(chuàng)建Vuex的store,使用分離store的方法,引入vuex import store from "./store" import ElementUI from "element-ui" import "element-ui/lib/theme-chalk/index.css" import Mock from "./mock/index" Mock.init() import axios from "axios" Vue.prototype.$ajax = axios // axios不能直接使用use引入,只能每個(gè)需要發(fā)送請(qǐng)求的組件中即時(shí)引入,兩種引入方式 // 第一種引入方式:引入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: "" })
至此,運(yùn)行npm run dev即可
文章結(jié)合了以下博客的內(nèi)容而成:
鏈接描述
鏈接描述
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/96234.html
摘要:適用于主要入口頁(yè)面生成多頁(yè),子頁(yè)面和次要頁(yè)面使用單頁(yè)形式的項(xiàng)目。文件用來(lái)存放固定的數(shù)據(jù),而文件可更加自由的處理并返回?cái)?shù)據(jù)。 VUE2的單頁(yè)應(yīng)用框架有人分享了,多頁(yè)應(yīng)用框架也有人分享了,這里分享一個(gè)單頁(yè)+多頁(yè)的混合應(yīng)用框架吧,node.js寫(xiě)了一個(gè)簡(jiǎn)單的mock服務(wù)也集成在里面,整體初現(xiàn)雛形,還有很多需要優(yōu)化和改善的地方。。。 項(xiàng)目結(jié)構(gòu) │ ├─build ...
摘要:遇到問(wèn)題時(shí)一定要去閱讀文檔,可以發(fā)現(xiàn)使用時(shí)遺漏或者沒(méi)有注意的地方。打包文件時(shí)也要注意修改路徑不然就踩坑了。 vue_lofter 一個(gè)仿lofte手機(jī)端的vue項(xiàng)目 項(xiàng)目描述 技術(shù)棧 Vue2.0全家桶 + axios + Vuex + Mint-ui + Mock.js + Stylus 預(yù)覽效果 ?預(yù)覽地址(PC端建議在Chrome下開(kāi)啟調(diào)試模式或移動(dòng)端瀏覽) ?源碼地址??求你...
摘要:請(qǐng)輸入正確的用戶(hù)名和密碼接下來(lái)是這個(gè)頁(yè)面很簡(jiǎn)單,簡(jiǎn)單的寫(xiě)一些內(nèi)容作為測(cè)試是否登錄跳轉(zhuǎn)成功。路由攔截中判斷對(duì)象是否為空。 需要解決的問(wèn)題:store存儲(chǔ)登錄狀態(tài)Vue-Router導(dǎo)航鉤子攔截路由Vue-Resource獲取后臺(tái)的數(shù)據(jù)需要判斷登錄返回的user源碼參考原文地址 主要技術(shù)棧:Vuex + Vue-Resource + Vue-Router后臺(tái)用mock-data來(lái)模擬數(shù)據(jù)。...
閱讀 1969·2021-09-30 09:46
閱讀 1378·2019-08-30 15:43
閱讀 1133·2019-08-29 13:28
閱讀 1934·2019-08-29 11:24
閱讀 1701·2019-08-26 13:22
閱讀 3982·2019-08-26 12:01
閱讀 1831·2019-08-26 11:33
閱讀 3253·2019-08-23 15:34