在vue-lic腳手架中安裝mockjs,實現先後端分離開發

在項目開發前期,前端開發中,頁面佈局基本開發完畢,可是後臺還接口尚未開發完,等待後臺開發完接口,在進行接口聯調,浪費了等待時間,也壓縮的測試的時間。因此實現請求攔截,前端模擬後臺請求數據就是一個很不錯的處理方式。html

mockjs

mockjs能夠生成隨機數據,攔截 Ajax 請求,讓前端攻城師獨立於後端進行開發。而且支持生成隨機的文本、數字、布爾值、日期、郵箱、連接、圖片、顏色等。前端

使用方法

mockjs 能夠很方便的添加到以webpack爲管理的項目中,以vue-cli腳手架生成的項目爲例。vue-cli的搭建不過多贅述,直接進入安裝插件過程。vue

用axios進行請求數據 因此安裝axios 和 mockjs 兩個包webpack

npm install axios --save 
npm install mockjs --save-dev

在src中建立一個mock文件夾 並建立一個mock.js文件
ios

// mock.js
// 引入mockjs
const Mock = require('mockjs');
// 建立模擬數據
let testData = {
    testData: '測試mock'
}
// Mock.mock( url, post/get , 返回的數據);
Mock.mock( '/getMockData', 'get' , testData)

在main.js中引入web

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'
import 'lib-flexible'
import axios from 'axios'
// 引入mockjs
require('./mock/mock.js')

// axios引入全局
Vue.prototype.$http = axios
Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})

在組件中使用vue-cli

<template>
  <div class="hello">
    <h1>{{ msg }}</h1>
    <h2>mockjs測試</h2>
    <div class="adbox">
        <div class="wrapper" v-if="hideType" id='mydiv' ref = 'mydiv'> 
        </div>
    </div>
  </div>
</template>

<script>
export default {
  name: 'HelloWorld',
  data () {
    return {
      msg: 'Welcome to Your Vue.js App',
      hideType: true,
    }
  },
  mounted() {
       this.getInfo()
  },
  methods: {
      getInfo() {
          this.$http.get('/getMockData')
          .then((res) => {
              console.log(res)
          })
          .catch(function (error) {
            console.log(error);
          });
      }
  }
}
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style lang="less" scoped>
  
h1, h2 {
  font-weight: normal;
}
ul {
  list-style-type: none;
  padding: 0;
  li {
      display: inline-block;
      padding: 0 10px;
      margin: 0 10px; /*no*/
    }
}

a {
  color: #42b983;
  font-size: 14px;
}

.adbox {
    position: relative;
}

.wrapper {
    position: absolute;
    top: 0;
    bottom: 0;
    background: #cccccc;
    margin: 0;
    width: 100%;
    opacity: 0.5;
    pointer-events: none;
    z-index: -10;
}
li:active {
    a:active {
        color: red;
    }
}

.hide {
    pointer-events: none;
}
</style>

在控制檯輸出數據 能夠看到 請求被攔截 而且返回了本身寫的測試數據
npm

mockjs 隨機數據功能

剛纔介紹了怎麼使用mockjs攔截數據,接下來講下mockjs另外一個核心內容,隨機生成數據axios

mockjs 支持生成隨機的文本、數字、布爾值、日期、郵箱、連接、圖片、顏色等。後端

咱們如今來改造下剛纔的模擬數據

// mock.js

// 引入mockjs
const Mock = require('mockjs');
// 獲取 mock.Random 對象
const Random = Mock.Random;
// 建立模擬數據
let testData = function() {
    let dataList = [];
    for (let i = 0; i < 10; i++) {
        let obj = {
            title: Random.csentence(10, 20), //  Random.csentence( min, max ) 隨機生成一段10-20長度的漢字字符串
            picture: Random.dataImage('100x100', '測試圖片'), // Random.dataImage( size, text ) 生成一段隨機的 Base64 圖片編碼
        }
        dataList.push(obj)
    }
 
    return {
        dataList: dataList
    }
}
Mock.mock( '/getMockData', 'get' , testData)
// Mock.mock( url, post/get , 返回的數據);

最終生成的數據

結語

mockjs官網中有不少的例子,能夠隨機生成多種數據,學會基本使用以後,能夠到官網中查看各類類型數據的隨機生成方法官網地址 http://mockjs.com/

相關文章
相關標籤/搜索