VUE—axios请求Echarts折线图

2019-07-12  本文已影响0人  大眼袋阿姨

1:安装echarts
cnpm install echarts --s
2:在需要用图表的地方引入
import echarts from 'echarts'
3.编写echarts.vue

<template>
    <div id="index">
        <div id="main" style="width: 100%;height: 400px;"></div>
    </div>
</template>
<script>
    import echarts from 'echarts'
    export default {
        name: 'index',
        data() {
            return {
                charts: '',
                opinionData: ["3", "2", "4", "4", "5"]
            }
        },
        methods: {
            drawLine(id) {
                this.charts = echarts.init(document.getElementById(id))
                this.charts.setOption({
                    tooltip: {
                        trigger: 'axis'
                    },
                    legend: {
                        data: ['近七日收益']
                    },
                    grid: {
                        left: '3%',
                        right: '4%',
                        bottom: '3%',
                        containLabel: true
                    },
                    toolbox: {
                        feature: {
                            saveAsImage: {}
                        }
                    },
                    xAxis: {
                        type: 'category',
                        boundaryGap: false,
                        data: ["1","2","3","4","5"]
                    },
                    yAxis: {
                        type: 'value'
                    },
                    series: [{
                        name: '近七日收益',
                        type: 'line',
                        stack: '总量',
                        data: this.opinionData
                    }]
                })
            }
        },
        mounted() {
            this.$nextTick(function() {
                this.drawLine('main')
            })
        }
    }
</script>

4.接口写在mock里面
首先在mock里面新建一个echarts.json

{
    "categories": [
        "1",
        "2",
        "3",
        "4",
        "5",
        "6",
        "7",
        "8",
        "9",
        "10",
        "11",
        "12"
    ],
    "data": [
        3,
        2,
        4,
        4,
        5
    ]
}

5:在build目录下找到webpack.dev.conf.js文件,编写以下代码

// mock code
const express = require('express')
const app = express()
const test = require('../mock/test.json') 
const echarts = require('../mock/echarts.json') 
const routes = express.Router()
app.use('/api', routes)
// 如果是post请求,那么将get改为post即可
devServer: {
 ...
 before(app){
 app.get('/api/test', (req, res) => {
  res.json(test)
 }),
 app.get('/api/echarts', (req, res) => {
  res.json(echarts)
 })
 }

6:浏览器输入http://localhost:8080/api/echarts
7.新代码

<template>
    <div id="index">
        <div id="main" style="width: 100%;height: 400px;"></div>
    </div>
</template>
<script>
import axios from "axios";
import echarts from 'echarts'
export default{
    name: "index",
    data() {
        return {
            charts: '',
            opinionData: []
        }
    },
    mounted() {
        this.getData();  
    },
    methods: {
        getData() {
            axios.get('http://localhost:8080/api/echarts').then(response => {
                console.log(response.data);
                this.opinionData =response.data.data;
                this.drawLine('main');
            }, response => {
                console.log("error");
            });
        },
        drawLine(id) {
            this.charts = echarts.init(document.getElementById(id))
            this.charts.setOption({
                tooltip: {
                    trigger: 'axis'
                },
                legend: {
                    data: ['近七日收益']
                },
                grid: {
                    left: '3%',
                    right: '4%',
                    bottom: '3%',
                    containLabel: true
                },

                toolbox: {
                    feature: {
                        saveAsImage: {}
                    }
                },
                xAxis: {
                    type: 'category',
                    boundaryGap: false,
                    data: ["1","2","3","4","5"]
                },
                yAxis: {
                    type: 'value'
                },
                series: [{
                    name: '近七日收益',
                    type: 'line',
                    stack: '总量',
                    data: this.opinionData
                }]
            })
        },
    }
}</script>
上一篇 下一篇

猜你喜欢

热点阅读