真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

詳解vue2.0+axios+mock+axios-mock+adapter實現(xiàn)登陸

做項目過程中,需要用到后臺模擬數(shù)據(jù),在機緣巧合下發(fā)現(xiàn)了mock,在學(xué)習(xí)使用的過程中又偶遇了axios-mock-adapter?,F(xiàn)在將實例展示如下:

在蟠龍等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站設(shè)計、網(wǎng)站制作 網(wǎng)站設(shè)計制作按需網(wǎng)站開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),全網(wǎng)整合營銷推廣,外貿(mào)網(wǎng)站建設(shè),蟠龍網(wǎng)站建設(shè)費用合理。

1、準(zhǔn)備

實例是建立在vue-cli的基礎(chǔ)上實現(xiàn)

需要提前安裝的插件有:

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');

代碼實例

整個項目的代碼結(jié)構(gòu)如下:

詳解vue2.0+axios+mock+axios-mock+adapter實現(xiàn)登陸

首先新建一個login.vue文件,代碼如下





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

import Vue from 'vue'
import Router from 'vue-router'
 
// 懶加載方式,當(dāng)路由被訪問的時候才加載對應(yīng)組件
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引入,只能每個需要發(fā)送請求的組件中即時引入,兩種引入方式
// 第一種引入方式:引入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: ''
})

刷新頁面

詳解vue2.0+axios+mock+axios-mock+adapter實現(xiàn)登陸

接下來就是對login.vue頁面進行改造:增加登錄點擊事件和重置事件

 
   login
   
    reset
   
  

此時的點擊事件沒有交互功能,使用axios和mock.js實現(xiàn)交互,并且使用axios-mock-adapter進行axios數(shù)據(jù)調(diào)試

在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

這是像后臺發(fā)起post請求,地址是‘user/login'

此處的后臺數(shù)據(jù)我們使用mockjs進行攔截,然后模擬后臺服務(wù)返回的數(shù)據(jù)

創(chuàng)建mock后臺模擬數(shù)據(jù)

在src目錄下創(chuàng)建mock文件夾,并且新建一個index.js,index.js內(nèi)容如下:、

// 通過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傳過來的數(shù)據(jù)
   let { username, password } = JSON.parse(config.data);
   return new Promise((resolve, reject) => {
    // 先創(chuàng)建一個用戶為空對象
    let user = null;
    setTimeout(() => {
     // 判斷模擬的假數(shù)據(jù)中是否有和傳過來的數(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 {
       // 如果沒有這個person
       return false
      }
     });
     // 如果有那么一個人
     if (hasUser) {
      resolve([ 200, {code: 200, msg: '登錄成功',user} ]);
     } else { // 如果沒有這么一個人
      resolve([ 200, {code: 500, msg: '賬號錯誤' }])
     }
    }, 500);
   })
  });
 // 模擬注冊接口
 }
}

接著在mock下建立data文件夾,;里面新建user.js用來存放用戶信息

/*
* 用來存放一些模擬用戶的數(shù)據(jù)
* */

// 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文件增加登錄方法

當(dāng)點擊登錄按鈕后,跳轉(zhuǎn)到‘/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';

// 懶加載方式,當(dāng)路由被訪問的時候才加載對應(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
  }
 ]
})

// 訪問之前,檢查是否登陸了
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';

// 懶加載方式,當(dāng)路由被訪問的時候才加載對應(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
  }
 ]
})

// 訪問之前,檢查是否登陸了
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即可

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


網(wǎng)頁題目:詳解vue2.0+axios+mock+axios-mock+adapter實現(xiàn)登陸
當(dāng)前鏈接:http://weahome.cn/article/gscojh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部