详解vue2.0+axios+mock+axios-mock+adapter实现登陆

前端之家收集整理的这篇文章主要介绍了详解vue2.0+axios+mock+axios-mock+adapter实现登陆前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

做项目过程中,需要用到后台模拟数据,在机缘巧合下发现了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的方式引入

第二种引入方式:以require方式引入

代码实例

整个项目的代码结构如下:

首先新建一个login.vue文件代码如下

<el-form
class="login-container"
ref="AccountForm"
:model="account"
:rules="loginRules"
label-position="left">

Login

记住密码

由于路由的默认指向是HelloWorld,所以修改router文件夹下的index.js

// 懒加载方式,当路由被访问的时候才加载对应组件
const Login = resolve => require(['@/components/Login'],resolve)

Vue.use(Router)

export default new Router({
routes: [{
path: '/',name: 'login',component: Login
}]

此时登录界面样式基本写好,接下来修改main.js,将需要引入的文件引入

如下:

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: ''
})

刷新页面

接下来就是对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 => {
return axios.post('/user/login',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 {
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',email: 'yyyyy@163.com',name: '混子'
}
]

export { users }

为login.vue文件增加登录方法

import {requseLogin} from "../axios/api";

export default {
name: "login",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()
},}
}

当点击登录按钮后,跳转到‘/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({
routes: [
{
path: '/',component: Login
},{
path: '/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

// 懒加载方式,当路由被访问的时候才加载对应组件
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即可

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

猜你在找的Vue相关文章