详解vue2.0+axios+mock+axios-mock+adapter实现登陆
做项目过程中,需要用到后台模拟数据,在机缘巧合下发现了mock,在学习使用的过程中又偶遇了axios-mock-adapter。现在将实例展示如下: 1、准备实例是建立在vue-cli的基础上实现 需要提前安装的插件有: axios: mockjs: axios-mock-adapter: 引入第一种引入方式:按照es6的语法,以import的方式引入 第二种引入方式:以require方式引入 代码实例整个项目的代码结构如下: 首先新建一个login.vue文件,代码如下 <el-form Login由于路由的默认指向是HelloWorld,所以修改router文件夹下的index.js // 懒加载方式,当路由被访问的时候才加载对应组件
const Login = resolve => require(['@/components/Login'],resolve) Vue.use(Router) export default new Router({ 此时登录界面样式基本写好,接下来修改main.js,将需要引入的文件引入 如下: import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css' import axios from 'axios' Vue.config.productionTip = false; / eslint-disable no-new / 刷新页面 接下来就是对login.vue页面进行改造:增加登录点击事件和重置事件 此时的点击事件没有交互功能,使用axios和mock.js实现交互,并且使用axios-mock-adapter进行axios数据调试 在src下新建一个axios文件夹,并建一个api.js axios.defaults.baseURL = 'http://127.0.0.1:80';
export const requseLogin = params => { 再新建一个index.js export default api
这是像后台发起post请求,地址是‘user/login' 此处的后台数据我们使用mockjs进行拦截,然后模拟后台服务返回的数据 创建mock后台模拟数据在src目录下创建mock文件夹,并且新建一个index.js,index.js内容如下:、 // import { LoginUsers } from './data/user'
import {users} from './data/user' export default { // mock success request 模拟成功请求 // login 模拟登录接口 接着在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',email: 'yyyyy@163.com',name: '混子' } ] export { users } 为login.vue文件增加登录方法
import {requseLogin} from "../axios/api";
export default {
},reset () { 当点击登录按钮后,跳转到‘/home'页面,在components文件夹下面新增home.vue文件 {{ msg }}接下了修改router中的index.js // 懒加载方式,当路由被访问的时候才加载对应组件
const Login = resolve => require(['@/components/Login'],resolve) const Home = resolve => require(['@/components/home'],resolve) Vue.use(Router) const router = new Router({ // 访问之前,检查是否登陆了 在main.js中引入mock // 懒加载方式,当路由被访问的时候才加载对应组件
const Login = resolve => require(['@/components/Login'],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即可 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |