做项目过程中,需要用到后台模拟数据,在机缘巧合下发现了mock,在学习使用的过程中又偶遇了axios-mock-adapter。现在将实例展示如下:
1、准备
实例是建立在vue-cli的基础上实现
需要提前安装的插件有:
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');
代码实例
整个项目的代码结构如下:
首先新建一个login.vue文件,代码如下
<template> <el-form class="login-container" ref="AccountForm" :model="account" :rules="loginRules" label-position="left"> <h3>Login</h3> <el-form-item prop="username"> <el-input v-model="account.username" type="text" placeholder="账号"> </el-input> </el-form-item> <el-form-item prop="password"> <el-input v-model="account.password" type="password" placeholder="密码"></el-input> </el-form-item> <el-checkbox v-model="checked" checked>记住密码</el-checkbox> <el-form-item> <el-button type="primary">login</el-button> <el-button type="primary">reset</el-button> </el-form-item> </el-form> </template> <script> import {requseLogin} from "../axios/api"; export default { name: "login", data () { return { account: { username: '', password: '' }, loginRules: { username: [{required: true, message: '请输入账号', trigger: 'blur'}], password: [{required: true,message: '请输入密码', trigger: 'blur'}], }, checked: true, logining: false }; }, methods: {} </script> <style scoped> body{ background: #DFE9FB; } .login-container { width:350px; margin-left:35%; border: 1px solid #d3d3d3; box-sizing: border-box; padding: 10px 30px; border-radius: 5px; } .el-button { width:100%; box-sizing: border-box; margin: 10px 0; } </style>
由于路由的默认指向是HelloWorld,所以修改router文件夹下的index.js
import Vue from 'vue' import Router from 'vue-router' // 懒加载方式,当路由被访问的时候才加载对应组件 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引入,只能每个需要发送请求的组件中即时引入,两种引入方式 // 第一种引入方式:引入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: '<App/>' })
刷新页面
接下来就是对login.vue页面进行改造:增加登录点击事件和重置事件
<el-form-item> <el-button @click.native.prevent="handleLogin" :loading="logining" type="primary">login</el-button> <el-button type="primary" class="resetBtn" @click.native.prevent="reset"> reset </el-button> </el-form-item>
此时的点击事件没有交互功能,使用axios和mock.js实现交互,并且使用axios-mock-adapter进行axios数据调试
在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
这是像后台发起post请求,地址是‘user/login'
此处的后台数据我们使用mockjs进行拦截,然后模拟后台服务返回的数据
创建mock后台模拟数据
在src目录下创建mock文件夹,并且新建一个index.js,index.js内容如下:、
// 通过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传过来的数据 let { username, password } = JSON.parse(config.data); return new Promise((resolve, reject) => { // 先创建一个用户为空对象 let user = null; setTimeout(() => { // 判断模拟的假数据中是否有和传过来的数据匹配的 let hasUser = users.some(person => { // 如果存在这样的数据 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用来存放用户信息
/* * 用来存放一些模拟用户的数据 * */ // 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文件增加登录方法
<script> import {requseLogin} from "../axios/api"; export default { name: "login", data () { return { account: { username: '', password: '' }, loginRules: { username: [{required: true, message: '请输入账号', trigger: 'blur'}], password: [{required: true,message: '请输入密码', trigger: 'blur'}], }, checked: true, logining: false }; }, methods: { handleLogin() { this.$refs.AccountForm.validate((valid) => { if (valid) { this.logining = true; let loginParams = { username: this.account.username, password: this.account.password } // 调用axios登录接口 requseLogin(loginParams).then(res => { // debugger; this.logining = false; // 根据返回的code判断是否成功 let { code, msg, user } = res.data; if (code === 200) { // elementui中提示组件 this.$message({ type: 'success', message: msg }); // 登陆成功,用户信息就保存在sessionStorage中 sessionStorage.setItem('user', JSON.stringify(user)); // 跳转到后台主页面 console.log('this',this) this.$router.push({ path: '/home' }) }else { this.$message({ type: 'error', message: msg, }); } }).catch(err =>{ console.log(err); }); }else { console.log('error submit!'); return false; } }) }, reset () { this.$refs.AccountForm.resetFields() }, } } </script>
当点击登录按钮后,跳转到‘/home'页面,在components文件夹下面新增home.vue文件
<template> <div > <h1>{{ msg }}</h1> </div> </template> <script> export default { name: '后台主界面', data () { return { msg: '后台主界面' } } } </script>
接下了修改router中的index.js
import Vue from 'vue' import Router from 'vue-router' // import HelloWorld from '@/components/HelloWorld' // import Home from '../components/home'; // 懒加载方式,当路由被访问的时候才加载对应组件 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'; // 懒加载方式,当路由被访问的时候才加载对应组件 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即可
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]