Vue脚手架中使用Mock模拟数据、aixos实现ecahrts

一 axios二次封装

 

安装axios:

npm i axios

在vue脚手架的main.js全局引入(axios不是插件,不能使用Vue.use方法引入)

import http from "axios";
Vue.prototype.$http = http;

创建api/config/index.js 文件:

export default{
    baseUrl:{
        dev:'/api/',//开发环境
        pro:'',//生产环境
    }
}

在api/axios.js封装axios类:

import axios from 'axios'
import config from '../config'

const baseUrl = process.env.NODE_ENV === 'development' ? config.baseUrl.dev : config.baseUrl.pro

class HttpRequest {
    constructor (baseUrl) {
        this.baseUrl = baseUrl
    }

    getInsideConfig() {
        const config = {
            baseUrl: this.baseUrl,
            header: {}
        }
        return config
    }
    interceptors (instance) {
        // 添加请求拦截器
        instance.interceptors.request.use(function (config) {
            // 在发送请求之前做些什么
            return config;
        }, function (error) {
            // 对请求错误做些什么
            return Promise.reject(error);
        });

        // 添加响应拦截器
        instance.interceptors.response.use(function (response) {
            // 对响应数据做点什么
            console.log(response)
            return response;
        }, function (error) {
            console.log(error, 'error')
            // 对响应错误做点什么
            return Promise.reject(error);
        });
    }
    request(options) {
        const instance =  axios.create()
        options = { ...this.getInsideConfig(), ...options }
        this.interceptors(instance)
        return instance(options)
    }
}

export default new HttpRequest(baseUrl)

 创建data.js:

import axios from './axios'
export const getMenu=(param)=>{
    return axios.request({
        url:'/permission/getMenu',
        method:'post',
        data:param
    })
}

二 mock数据模拟

(1)安装

npm i mock

(2)在api/mockServerData/home.js添加

// mock数据模拟
import Mock from 'mockjs'

// 图表数据
let List = []
export default {
  getStatisticalData: () => {
    //Mock.Random.float 产生随机数100到8000之间 保留小数 最小0位 最大0位
    for (let i = 0; i < 7; i++) {
      List.push(
        Mock.mock({
          苹果: Mock.Random.float(100, 8000, 0, 0),
          vivo: Mock.Random.float(100, 8000, 0, 0),
          oppo: Mock.Random.float(100, 8000, 0, 0),
          魅族: Mock.Random.float(100, 8000, 0, 0),
          三星: Mock.Random.float(100, 8000, 0, 0),
          小米: Mock.Random.float(100, 8000, 0, 0)
        })
      )
    }
    return {
      code: 20000,
      data: {
        // 饼图
        videoData: [
          {
            name: '小米',
            value: 2999
          },
          {
            name: '苹果',
            value: 5999
          },
          {
            name: 'vivo',
            value: 1500
          },
          {
            name: 'oppo',
            value: 1999
          },
          {
            name: '魅族',
            value: 2200
          },
          {
            name: '三星',
            value: 4500
          }
        ],
        // 柱状图
        userData: [
          {
            date: '周一',
            new: 5,
            active: 200
          },
          {
            date: '周二',
            new: 10,
            active: 500
          },
          {
            date: '周三',
            new: 12,
            active: 550
          },
          {
            date: '周四',
            new: 60,
            active: 800
          },
          {
            date: '周五',
            new: 65,
            active: 550
          },
          {
            date: '周六',
            new: 53,
            active: 770
          },
          {
            date: '周日',
            new: 33,
            active: 170
          }
        ],
        // 折线图
        orderData: {
          date: ['20191001', '20191002', '20191003', '20191004', '20191005', '20191006', '20191007'],
          data: List
        },
       
      }
    }
  }
}

在api/mock.js添加: 

import Mock from 'mockjs'
import homeApi from './mockServerData/home'
//  拦截器规则        url地址        回调函数返回具体的数据
Mock.mock('/home/getData',homeApi.getStatisticalData)

(3)在main.js中进行引入

import "../api/mock.js";

三 使用

(1)在data.js添加如下代码:

export const  getData=()=>{
    return axios.request({
        url:'/home/getData',
        methods:'get',
    })
}

(2)在public/index.html页面引入echarts


    

(3)安装element-ui(全局引入)

终端输入:

npm i element-ui -s

在main.js加上下段代码 :

import ElementUI from 'element-ui'
import "element-ui/lib/theme-chalk/index.css";
Vue.use(ElementUI)

(4)views/home/index.vue页面:




实现效果图:

Vue脚手架中使用Mock模拟数据、aixos实现ecahrts_第1张图片

 四 封装Echarts

(1)在components文件夹创建Echarts.vue,并在上面添加如下代码



(2)views/home/index.vue修改代码步骤

1)引入

import Echart from '../../components/Echarts.vue'

2)修改如红方框所示

Vue脚手架中使用Mock模拟数据、aixos实现ecahrts_第2张图片

 3)添加如下红方框代码Vue脚手架中使用Mock模拟数据、aixos实现ecahrts_第3张图片

 4)

折线图代码:

Vue脚手架中使用Mock模拟数据、aixos实现ecahrts_第4张图片

柱状图代码: 

Vue脚手架中使用Mock模拟数据、aixos实现ecahrts_第5张图片

Vue脚手架中使用Mock模拟数据、aixos实现ecahrts_第6张图片

 饼图代码:Vue脚手架中使用Mock模拟数据、aixos实现ecahrts_第7张图片

你可能感兴趣的:(Mock,前端vue,前端,javascript,vue.js)