安装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
})
}
(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页面:
实现效果图:
(1)在components文件夹创建Echarts.vue,并在上面添加如下代码
(2)views/home/index.vue修改代码步骤
1)引入
import Echart from '../../components/Echarts.vue'
2)修改如红方框所示
4)
折线图代码:
柱状图代码: