欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Echart圖表在項目中的前后端使用詳解

 更新時間:2021年11月24日 14:16:46   作者:沉默著忍受  
圖表在我們的項目中可以幫我們很明確的看到我們想要看到的數(shù)據(jù),本文將主要介紹Echart圖表在項目中前后端使用的詳細教程,感興趣的同學可以學習一下

前言

圖表在我們的項目中可以幫我們很明確的看到我們想要看到的數(shù)據(jù),并且通過操控圖表,可以很快獲得你想要的信息,在b站上同學們看見一些炫酷的可視化圖表時否覺得好炫酷,好牛逼。一看這個項目就很nb,現(xiàn)在臨近畢業(yè)設計階段,學會如何使用Echart圖表,或許會讓你的項目打動老師,也會讓你在編寫論文中有話好說。在工作中會一手圖表,在leader眼中你就是個人才。好了,廢話不多說,開干!

一、項目架構(gòu)

我的文章會涉及圖片中的表格使用,如果你都學會了,可以去Echart官網(wǎng)使用更高級炫酷的表了。

二、進入Echart官網(wǎng)學會自我分析

2.1 Echart官方文檔

Echart官網(wǎng)

進入官網(wǎng)

進入所有實例

點擊基礎折線圖

以上就是你在使用Echart圖表所需要的步驟。

2.2 Echart基礎代碼常識

我們引入基礎折圖來講解:

import * as echarts from 'echarts';//引入echarts資源

var chartDom = document.getElementById('main');//定位你圖表顯示的前端id=main的塊
var myChart = echarts.init(chartDom);//初始化前端塊中的圖表
var option; //圖表對象

option = {
  xAxis: { //圖標對象中x軸
    type: 'category', //線條類型
    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] //當前軸上的數(shù)據(jù)
  },
  yAxis: { //圖標對象中y軸
    type: 'value' //類型為value
  },
  series: [
    { //與x軸對應的對象值,比如‘Mon'對'150'
      data: [150, 230, 224, 218, 135, 147, 260],
      type: 'line' //類型是線條
    }
  ]
};

option && myChart.setOption(option); //將option對象存入chart,setOption的意思就是修改。

三,折線圖使用

3.1 基礎折線圖

前端實現(xiàn):

  1. 創(chuàng)建一個.vue文件
  2. 定義一個顯示圖表的前端代碼塊
  3. 定位id
  4. 初始化chart
  5. 定義option對象
  6. 調(diào)用創(chuàng)建方法

創(chuàng)建一個.vue文件

頁面結(jié)構(gòu):

<template>
  //這里放表的div
</template>

<script>

export default{ //JS代碼塊框架

    data(){
        return{

        }
    }

    
}

</script>

定義一個顯示圖表的前端代碼塊

<template>
<div class="width:600px;height:400;">
   <div id="main"></div>  
</div>
</template>
<script>
export default{

    data(){
        return{

        }
    }  
}

</script>

定位id并初始化chart

<template>
    <!-- 用來放echarts圖表的容器,一定要有寬高 -->
 <div>
 <div id="main" style="height: 300px;width: 400px;"></div>
</div>

</template>


<script>
import * as echarts from 'echarts';
export default {
    data (){
        return{
        }
    },
    mounted() {
        this.getchart();//定義一個接口方法在methods中調(diào)用 
    },
    methods: {
   
        //圖表方法
        getchart() {
            //獲取id并初始化圖表
            var chartDom  = document.getElementById('main');
            var myChart = echarts.init(chartDom);
            //配置項
            var option;
            option = {
           xAxis: {
              type: 'category',
              data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
            },
           yAxis: {
            type: 'value'
             },
            series: [
              {
              data: [150, 230, 224, 218, 135, 147, 260],
           type: 'line'
             }
           ]
         };
            option && myChart.setOption(option)//通過setOption()方法生成圖表
        },
    },
}
</script>
<style scoped>
    .generalStyle {
        width: 100%;
        height: 90%;
    }
</style>

運行結(jié)果:

現(xiàn)在我們前端已經(jīng)可以展示了,但是前端的數(shù)據(jù)是寫死的,如何才可以調(diào)用后端來實現(xiàn)數(shù)據(jù)的前后端交互呢?

后端實現(xiàn):

  1. 分析前端代碼
  2. 前端編寫請求方法
  3. 前端替換數(shù)據(jù)
  4. 編寫后端方法

分析前端代碼:

編寫請求方法

我們在methods中編寫請求接口的代碼,我們用到的是axios。

在我們的vue項目中的main.js中設置路由,

import Vue from 'vue'
import App from './App.vue'
import router from './router' 
import './assets/css/global.css'

// 導入iconfront
import './assets/font/iconfont.css'
// 導入axios
import axios from 'axios'
Vue.prototype.$echarts = window.echarts
// 掛載axios 到Vue的原型prototype的$http
Vue.prototype.$http = axios
// 設置請求的根路徑
axios.defaults.baseURL = "http://localhost:9000/" //項目上線改為后臺服務器域名,即可實現(xiàn)域名綁定
axios.interceptors.request.use(config => {
  console.log(config);
  // 請求頭掛載信息
  config.headers.Authorization = window.sessionStorage.getItem("flag");
  // 在最后必須return config
  return config;
})
Vue.config.productionTip = false

new Vue({
  router,
  render: h => h(App)
}).$mount('#app')

然后回到剛剛創(chuàng)建的vue頁面編寫接口請求方法:

在data中定義下x,ydata變量

      data (){
        return{
            xdata:[], //保存接口返回的x軸坐標數(shù)據(jù)
            ydata:[]  //保存接口返回的y軸坐標數(shù)據(jù)
        }
    },

在methods編寫接口方法;

    //調(diào)用后端接口

       async getSendata(){

        const { data: res } = await this.$http.post("api/echartdata"); //調(diào)用后端接口為api/echartdata的接口

        if(res!=null){
            //后端定義一個保存字符串的鏈表,通過‘,'切分,返回一個數(shù)組,或者后端返回一個數(shù)組鏈表
             this.xdata = res[0].split(","); //res是鏈表類型,第一個元素保存x軸data
             this.ydata = res[1].split(","); //res是鏈表類型,第二個元素保存y軸data
        }
        this.getchart() //數(shù)據(jù)獲取完成重新初始表;
       },
          

替換數(shù)據(jù)

將表中的x軸data和y軸data替換為我們在data中定義好的:

xdata:[], //保存接口返回的x軸坐標數(shù)據(jù)

ydata:[] //保存接口返回的y軸坐標數(shù)據(jù)

后端代碼

在controller層里編寫接口方法:

    @PostMapping("/api/echartdata")
    public String getchartdata(){
      String x = "阿里,騰訊,百度,京東,美團";
      String y = "200,120,200,160,120";
      List<String> list = new LinkedList<>();
      list.add(x);
      list.add(y);
      String s = JSON.toJSONString(list);
        System.out.println(s);
      return s;
    }

我們這里就完整的寫好了,現(xiàn)在開始運行;

記得初始化接口方法,才可以拿到后臺數(shù)據(jù);

前后端執(zhí)行成功!

完整代碼:

前端:

<template>
    <!-- 用來放echarts圖表的容器,一定要有寬高 -->
 <div>
 <div id="main" style="height: 300px;width: 400px;"></div>
</div>

</template>


<script>
import * as echarts from 'echarts';
export default {
    data (){
        return{
            xdata:[], //保存接口返回的x軸坐標數(shù)據(jù)
            ydata:[]  //保存接口返回的y軸坐標數(shù)據(jù)
        }
    },
    mounted() {
        this.getSendata();//定義一個接口方法在methods中調(diào)用 
    },
    methods: {
       
       //調(diào)用后端接口

       async getSendata(){

        const { data: res } = await this.$http.post("api/echartdata"); //調(diào)用后端接口為api/echartdata的接口

        if(res!=null){
            //后端定義一個保存字符串的鏈表,通過‘,'切分,返回一個數(shù)組,或者后端返回一個數(shù)組鏈表
             this.xdata = res[0].split(","); //res是鏈表類型,第一個元素保存x軸data
             this.ydata = res[1].split(","); //res是鏈表類型,第二個元素保存y軸data
        }
        this.getchart() //數(shù)據(jù)獲取完成重新初始表;
       },
          

        //圖表方法
        getchart() {
            //獲取id并初始化圖表
            var chartDom  = document.getElementById('main');
            var myChart = echarts.init(chartDom);
            //配置項
            var option;
            option = {
           xAxis: {
              type: 'category',
              data: this.xdata,
            },
           yAxis: {
            type: 'value'
             },
            series: [
              {
              data:this.ydata,
           type: 'line'
             }
           ]
         };
            option && myChart.setOption(option)//通過setOption()方法生成圖表
        },
    },
}
</script>
<style scoped>
    .generalStyle {
        width: 100%;
        height: 90%;
    }
</style>

3.2 平滑折線圖

我們在基礎折線圖里已經(jīng)完成了代碼框架的搭建,所以我們只需要去Echart實例里將我們初始化Echart函數(shù)換掉就可以;

完整代碼:

<template>
    <!-- 用來放echarts圖表的容器,一定要有寬高 -->
 <div>
 <div id="main" style="height: 300px;width: 400px;"></div>
</div>

</template>


<script>
import * as echarts from 'echarts';
export default {
    data (){
        return{
            xdata:[], //保存接口返回的x軸坐標數(shù)據(jù)
            ydata:[]  //保存接口返回的y軸坐標數(shù)據(jù)
        }
    },
    mounted() {
        this.getSendata();//定義一個接口方法在methods中調(diào)用 
    },
    methods: {
       
       //調(diào)用后端接口

       async getSendata(){

        const { data: res } = await this.$http.post("api/echartdata"); //調(diào)用后端接口為api/echartdata的接口

        if(res!=null){
            //后端定義一個保存字符串的鏈表,通過‘,'切分,返回一個數(shù)組,或者后端返回一個數(shù)組鏈表
             this.xdata = res[0].split(","); //res是鏈表類型,第一個元素保存x軸data
             this.ydata = res[1].split(","); //res是鏈表類型,第二個元素保存y軸data
        }
        this.getchart() //數(shù)據(jù)獲取完成重新初始表;
       },
          

        //圖表方法
        getchart() {
            //獲取id并初始化圖表
       var chartDom = document.getElementById('main');
       var myChart = echarts.init(chartDom);  
       var option;

     option = {
      xAxis: {
      type: 'category',
      data:this.xdata
     },
     yAxis: {
      type: 'value'
     },
     series: [
      {
      data: this.ydata,
      type: 'line',
      smooth: true
      }
    ]
  };
    option && myChart.setOption(option);
        },
    },
}
</script>
<style scoped>
    .generalStyle {
        width: 100%;
        height: 90%;
    }
</style>

執(zhí)行結(jié)果:

3.3 面積折線圖

還是不用多說我們直接換,但是剛剛平滑折線圖不知道你有沒有發(fā)現(xiàn),就是其實和基礎的折線圖代碼就在series中加了一個屬性:

  series: [
    {
      data: [820, 932, 901, 934, 1290, 1330, 1320],
      type: 'line',
      smooth: true //開啟平滑
    }
  ]

所以面積折線圖也只需要修改series中的屬性

  series: [
    {
      data: [820, 932, 901, 934, 1290, 1330, 1320],
      type: 'line',
      areaStyle: {} //面積屬性
    }
  ]

看效果:

3.4 炫酷組合圖

同樣方法,替換初始化表格的方法,在將數(shù)據(jù)替換為后端接口返回的數(shù)據(jù)就可以為所欲為了!

在方法中直接引入后端接口返回res

將source數(shù)據(jù)替換

前端完整代碼:

<template>
    <!-- 用來放echarts圖表的容器,一定要有寬高 -->
 <div>
 <div id="main" style="height: 300px;width: 400px;"></div>
</div>

</template>


<script>
import * as echarts from 'echarts';
export default {
    data (){
        return{
            xdata:[], //保存接口返回的x軸坐標數(shù)據(jù)
            ydata:[]  //保存接口返回的y軸坐標數(shù)據(jù)
        }
    },
    mounted() {
        this.getchart();//定義一個接口方法在methods中調(diào)用 
    },
    methods: {
       

        //圖表方法
        getchart() {
            //獲取id并初始化圖表
            //調(diào)用后端接口   
            const { data: res } = await this.$http.post("api/echartdata1"); //調(diào)用后端接口為api/echartdata的接口
            var chartDom = document.getElementById('main');
            var myChart = echarts.init(chartDom);
            var option;

            setTimeout(function () {
       option = {
      legend: {},
      tooltip: {
      trigger: 'axis',
      showContent: false
    },
    dataset: {
      source: [
         res[0].split(","),
         res[1].split(","),
         res[2].split(","),
         res[3].split(","),
         res[4].split(","),
      ]
    },
    xAxis: { type: 'category' },
    yAxis: { gridIndex: 0 },
    grid: { top: '55%' },
    series: [
      {
        type: 'line',
        smooth: true,
        seriesLayoutBy: 'row',
        emphasis: { focus: 'series' }
      },
      {
        type: 'line',
        smooth: true,
        seriesLayoutBy: 'row',
        emphasis: { focus: 'series' }
      },
      {
        type: 'line',
        smooth: true,
        seriesLayoutBy: 'row',
        emphasis: { focus: 'series' }
      },
      {
        type: 'line',
        smooth: true,
        seriesLayoutBy: 'row',
        emphasis: { focus: 'series' }
      },
      {
        type: 'pie',
        id: 'pie',
        radius: '30%',
        center: ['50%', '25%'],
        emphasis: {
          focus: 'self'
        },
        label: {
          formatter: ': {@2012} (vvxyksv9kd%)'
        },
        encode: {
          itemName: 'product',
          value: '2012',
          tooltip: '2012'
        }
      }
    ]
  };
  myChart.on('updateAxisPointer', function (event) {
    const xAxisInfo = event.axesInfo[0];
    if (xAxisInfo) {
      const dimension = xAxisInfo.value + 1;
      myChart.setOption({
        series: {
          id: 'pie',
          label: {
            formatter: ': {@[' + dimension + ']} (vvxyksv9kd%)'
          },
          encode: {
            value: dimension,
            tooltip: dimension
          }
        }
      });
    }
  });
  myChart.setOption(option);
});

option && myChart.setOption(option);

        },
    },
}
</script>
<style scoped>
    .generalStyle {
        width: 100%;
        height: 90%;
    }
</style>

后端完整代碼:

 @PostMapping("/api/echartdata1")
    public String getchartdata1(){
        String data1 = "product, 2012, 2013, 2014, 2015, 2016, 2017";
        String data2 = "騰訊, 56.5, 82.1, 88.7, 70.1, 53.4, 85.1";
        String data3 = "阿里, 51.1, 51.4, 55.1, 53.3, 73.8, 68.7";
        String data4 = "京東, 40.1, 62.2, 69.5, 36.4, 45.2, 32.5";
        String data5 = "百度, 25.2, 37.1, 41.2, 18, 33.9, 49.1";
        List<String> list = new LinkedList<>();
        list.add(data1);
        list.add(data2);
        list.add(data3);
        list.add(data4);
        list.add(data5);
        String s = JSON.toJSONString(list);
        System.out.println(s);
        return s;
    }

運行:

以上就是Echart圖表在項目中的前后端使用詳解的詳細內(nèi)容,更多關于Echart圖表使用的資料請關注腳本之家其它相關文章!

相關文章

  • vue2中使用less簡易教程

    vue2中使用less簡易教程

    這篇文章主要介紹了vue2中使用less簡易教程,由于不需要手動配置webpack,所以vue中使用less是非常簡單的,只需要安裝less,less-loadder就ok了
    2018-03-03
  • vue init webpack 建vue項目報錯的解決方法

    vue init webpack 建vue項目報錯的解決方法

    今天小編就為大家分享一篇vue init webpack 建vue項目報錯的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue實現(xiàn)拖放排序功能的實例代碼

    Vue實現(xiàn)拖放排序功能的實例代碼

    本文通過實例代碼給大家介紹了Vue中實現(xiàn)拖放排序功能,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • vue實現(xiàn)移動端原生小球滑塊

    vue實現(xiàn)移動端原生小球滑塊

    這篇文章主要為大家詳細介紹了vue實現(xiàn)移動端原生小球滑塊,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue+elemen實現(xiàn)el-tooltip在文本超出區(qū)域后浮現(xiàn)

    vue+elemen實現(xiàn)el-tooltip在文本超出區(qū)域后浮現(xiàn)

    el-tooltip組件本身就是懸浮提示功能,在對它進行二次封裝時,實現(xiàn)超出的文本浮現(xiàn),本文就來介紹一下vue+elemen實現(xiàn)el-tooltip在文本超出區(qū)域后浮現(xiàn),感興趣的可以了解一下
    2023-12-12
  • Vue判斷字符串(或數(shù)組)中是否包含某個元素的多種方法

    Vue判斷字符串(或數(shù)組)中是否包含某個元素的多種方法

    在我們前端日常開發(fā)中經(jīng)常會遇到判斷一個字符串中是否包含某個元素的需求,下面這篇文章主要給大家介紹了關于Vue判斷字符串(或數(shù)組)中是否包含某個元素的多種方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • webpack項目中使用vite加速的兼容模式詳解

    webpack項目中使用vite加速的兼容模式詳解

    這篇文章主要為大家介紹了webpack項目中使用vite加速的兼容模式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 如何理解Vue簡單狀態(tài)管理之store模式

    如何理解Vue簡單狀態(tài)管理之store模式

    狀態(tài)管理也就是數(shù)據(jù)狀態(tài)管理,vue應用程序的各組件之間經(jīng)常需要進行通信,除了v-on、EventBus等通信方式外,可以采用數(shù)據(jù)共享的方式進行通信。這種簡單的數(shù)據(jù)共享模式就是store模式。
    2021-05-05
  • vue實現(xiàn)輸入框只允許輸入數(shù)字

    vue實現(xiàn)輸入框只允許輸入數(shù)字

    在vue項目中,輸入框只允許輸入數(shù)字,現(xiàn)將自己使用的一種方法記錄,本文結(jié)合實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧
    2023-11-11
  • Vue3?props的使用示例詳解

    Vue3?props的使用示例詳解

    這篇文章主要介紹了Vue3?props的使用詳解,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-10-10

最新評論