资讯专栏INFORMATION COLUMN

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

RancherLabs / 2227人阅读

摘要:做项目过程中,需要用到后台模拟数据,在机缘巧合下发现了,在学习使用的过程中又偶遇了。

做项目过程中,需要用到后台模拟数据,在机缘巧合下发现了mock,在学习使用的过程中又偶遇了axios-mock-adapter。现在将实例展示如下:

准备

实例是建立在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文件,代码如下






由于路由的默认指向是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: ""
})

刷新页面

接下来就是对login.vue页面进行改造:增加登录点击事件和重置事件

    
      login
      
        reset
      
    

此时的点击事件没有交互功能,使用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文件增加登录方法


当点击登录按钮后,跳转到‘/home’页面,在components文件夹下面新增home.vue文件



接下了修改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 App from "./App"
import router from "./router"

//创建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引入,只能每个需要发送请求的组件中即时引入,两种引入方式
// 第一种引入方式:引入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: ""
})

至此,运行npm run dev即可

文章结合了以下博客的内容而成:
链接描述

链接描述

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/96234.html

相关文章

  • webpack4+vue2+axios+vue-router的多页+单页混合应用框架

    摘要:适用于主要入口页面生成多页,子页面和次要页面使用单页形式的项目。文件用来存放固定的数据,而文件可更加自由的处理并返回数据。 VUE2的单页应用框架有人分享了,多页应用框架也有人分享了,这里分享一个单页+多页的混合应用框架吧,node.js写了一个简单的mock服务也集成在里面,整体初现雏形,还有很多需要优化和改善的地方。。。 项目结构 │ ├─build ...

    whatsns 评论0 收藏0
  • 前端mock数据的各种姿势

    1、mocker.js2、axios-mocker3、mocker-api server 未完 ,待续…… 标题文字

    BWrong 评论0 收藏0
  • vue仿lofter移动端demo

    摘要:遇到问题时一定要去阅读文档,可以发现使用时遗漏或者没有注意的地方。打包文件时也要注意修改路径不然就踩坑了。 vue_lofter 一个仿lofte手机端的vue项目 项目描述 技术栈 Vue2.0全家桶 + axios + Vuex + Mint-ui + Mock.js + Stylus 预览效果 ?预览地址(PC端建议在Chrome下开启调试模式或移动端浏览) ?源码地址✨✨求你...

    wwolf 评论0 收藏0
  • Vue2.0一个login跳转实例

    摘要:请输入正确的用户名和密码接下来是这个页面很简单,简单的写一些内容作为测试是否登录跳转成功。路由拦截中判断对象是否为空。 需要解决的问题:store存储登录状态Vue-Router导航钩子拦截路由Vue-Resource获取后台的数据需要判断登录返回的user源码参考原文地址 主要技术栈:Vuex + Vue-Resource + Vue-Router后台用mock-data来模拟数据。...

    ninefive 评论0 收藏0

发表评论

0条评论

RancherLabs

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<