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

VUE引入使用G2圖表的實現(xiàn)

 更新時間:2021年08月18日 09:43:00   作者:黃勇超  
本文主要介紹了VUE引入使用G2圖表的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

關(guān)于G2圖表介紹

G2 是一套基于圖形語法理論的可視化底層引擎,以數(shù)據(jù)驅(qū)動,提供圖形語法與交互語法,具有高度的易用性和擴展性
使用 G2,可以無需關(guān)注圖表各種繁瑣的實現(xiàn)細節(jié),一條語句即可使用 Canvas 或 SVG 構(gòu)建出各種各樣的可交互的統(tǒng)計圖表

G2圖表官網(wǎng)地址
https://antv.gitee.io/zh

G2圖標詳細開發(fā)手冊
https://antv-g2.gitee.io/zh/docs/api/general/chart

使用

第一步:安裝G2依賴包

npm instal @antv/g2

第二步:在繪圖前需要為 G2 準備一個 DOM 容器

<div id="webInfo"></div>

第三步:引入

import G2 from "@antv/g2";

第四步:在mounted中定義

可先在全局定義let chart = null;

const chart = new G2.Chart({})

chart = new G2.Chart({       
        container: "webInfo",//指定圖表容器       
        forceFit: true,//強制配合 
        width: 600, // 指定圖表寬度       
        height: 306,//高度       
        padding: [20, 30, 30, 50],//內(nèi)邊距 
})

第五步:載入數(shù)據(jù)源

/馬上更新圖表 / 
chart.changeData(chartData) 

/僅僅是更新數(shù)據(jù),而不需要馬上更新圖表/ 
chart.source(chartData) 

/需要更新圖表時調(diào)用 / 
chart.repaint()

擴展清除圖形語法

/清理所有/
chart.clear(); 

模板中使用完整代碼(柱狀圖)

<template>
  <div id="c1"></div>
</template>
<script>
    export default {
        name: "spectaculars",
        data(){
            return{
                basicColumnChartProp:{
                    data:[{ genre: 'Sports', sold: 275 },
                        { genre: 'Strategy', sold: 115 },
                        { genre: 'Action', sold: 120 },
                        { genre: 'Shooter', sold: 350 },
                        { genre: 'Other', sold: 150 }],
                    container:'c1',
                    width:700,
                    height:600
                },
            }
        },
        methods:{
            test(){
                const data = this.basicColumnChartProp.data;
                const chart = new G2.Chart({
                    container: this.basicColumnChartProp.container,
                    width : this.basicColumnChartProp.width,
                    height : this.basicColumnChartProp.height
                });
                chart.source(data);
                chart.interval().position('genre*sold').color('genre')
                chart.render();
            }
        },    
        mounted() {
          this.test();
        },
    }
</script>

在補充一下世界地圖

(當初項目需求找了G2的地圖,感覺API文檔有些東西沒說明白,這里記錄一下)

<template>
  <div id="c1"></div>
</template>
<script>
    const DataSet = require('@antv/data-set');
    export default {
        name: "spectaculars",
        data(){
            return{
                basicColumnChartProp:{
                    container:'c1',
                },
            }
        },
        methods:{
            test(){
              fetch('src/views/dataCenter/data/world/countries.geo.json')
              .then(res => res.json())
              .then(mapData => {
                const chart = new G2.Chart({
                  container:this.basicColumnChartProp.container,
                  forceFit: true,
                  height:700,
                  padding: [10,10]
                });
                chart.tooltip({
                  showTitle: false
                });
                // 同步度量
                chart.scale({
                  longitude: {
                    sync: true
                  },
                  latitude: {
                    sync: true
                  }
                });
                chart.axis(false);
                chart.legend('trend', {
                  position: 'left'
                });
 
                // 繪制世界地圖背景
                const ds = new DataSet();
                const worldMap = ds.createView('back')
                  .source(mapData, {
                    type: 'GeoJSON'
                  });
                const worldMapView = chart.view();
                worldMapView.source(worldMap);
                worldMapView.tooltip(false);
                worldMapView.polygon().position('longitude*latitude').style({
                  fill: '#fff',
                  stroke: '#ccc',
                  lineWidth: 1
                });
 
                const userData = [
                  { name: 'Russia', value: 86.8 },
                  { name: 'China', value: 106.3 },
                  { name: 'Japan', value: 94.7 },
                  { name: 'Mongolia', value: 98 },
                  { name: 'Canada', value: 98.4 },
                  { name: 'United Kingdom', value: 97.2 },
                  { name: 'United States of America', value: 98.3 },
                  { name: 'Brazil', value: 96.7 },
                  { name: 'Argentina', value: 95.8 },
                  { name: 'Algeria', value: 101.3 },
                  { name: 'France', value: 94.8 },
                  { name: 'Germany', value: 96.6 },
                  { name: 'Ukraine', value: 86.3 },
                  { name: 'Egypt', value: 102.1 },
                  { name: 'South Africa', value: 101.3 },
                  { name: 'India', value: 107.6 },
                  { name: 'Australia', value: 99.9 },
                  { name: 'Saudi Arabia', value: 130.1 },
                  { name: 'Afghanistan', value: 106.5 },
                  { name: 'Kazakhstan', value: 93.4 },
                  { name: 'Indonesia', value: 101.4 }
                ];
                const userDv = ds.createView()
                  .source(userData)
                  .transform({
                    geoDataView: worldMap,
                    field: 'name',
                    type: 'geo.region',
                    as: [ 'longitude', 'latitude' ]
                  })
                  .transform({
                    type: 'map',
                    callback: obj => {
                      // obj.trend = obj.value
                      obj.trend = (obj.value > 100) ? '男性更多' : '女性更多';
                      return obj;
                    }
                  });
                const userView = chart.view();
                userView.source(userDv, {
                  trend: {
                    alias: '每100位女性對應(yīng)的男性數(shù)量'
                  }
                });
                userView.polygon()
                  .position('longitude*latitude')
                  .color('trend', [ '#F51D27', '#0A61D7' ])
                  .opacity('value')
                  .tooltip('name*trend')
                  .animate({
                    leave: {
                      animation: 'fadeOut'
                    }
                  });
                chart.render();
              })
            },
        },
        mounted() {
          this.test();
        },
    }
</script>
  • fetch這個地方官網(wǎng)引入的是文件目錄,不是具體的json文件,使用的時候找不到文件
  • fetch引入的json這里是本地的,其次G2官網(wǎng)提供的遠程githup地址獲取不到這個json文件
  • fetch引入json文件的路徑,不是你當前文件到該json的路徑,而是index.html到該json文件的地址

到此這篇關(guān)于VUE引入使用G2圖表的實現(xiàn)的文章就介紹到這了,更多相關(guān)VUE使用G2圖表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用vue-cli腳手架工具搭建vue-webpack項目

    使用vue-cli腳手架工具搭建vue-webpack項目

    這篇文章主要介紹了使用vue-cli腳手架工具搭建vue-webpack項目,通過幾個默認的步驟幫助你快速的構(gòu)建Vue.js項目。非常具有實用價值,需要的朋友可以參考下
    2019-01-01
  • 詳解如何實現(xiàn)一個簡單的 vuex

    詳解如何實現(xiàn)一個簡單的 vuex

    本篇文章主要介紹了如何實現(xiàn)一個簡單的 vuex,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • 多個vue項目復(fù)用一個node_modules的問題

    多個vue項目復(fù)用一個node_modules的問題

    這篇文章主要介紹了多個vue項目復(fù)用一個node_modules的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue實現(xiàn)下拉菜單效果

    vue實現(xiàn)下拉菜單效果

    這篇文章主要為大家詳細介紹了vue實現(xiàn)下拉菜單效果,運用了hover顯示與隱藏以及定位,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • vue+vue-meta-info動態(tài)設(shè)置meta標簽教程

    vue+vue-meta-info動態(tài)設(shè)置meta標簽教程

    這篇文章主要介紹了vue+vue-meta-info動態(tài)設(shè)置meta標簽教程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue2.x中利用@font-size引入字體圖標報錯的解決方法

    Vue2.x中利用@font-size引入字體圖標報錯的解決方法

    今天小編就為大家分享一篇Vue2.x中利用@font-size引入字體圖標報錯的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 詳解vue為什么要求組件模板只能有一個根元素

    詳解vue為什么要求組件模板只能有一個根元素

    這篇文章主要介紹了vue為什么要求組件模板只能有一個根元素,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-07-07
  • vue雙向綁定的簡單實現(xiàn)

    vue雙向綁定的簡單實現(xiàn)

    這篇文章主要為大家詳細介紹了vue雙向綁定的簡單實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • vue?this.$router六種方法使用示例總結(jié)分析

    vue?this.$router六種方法使用示例總結(jié)分析

    這篇文章主要為大家介紹了vue this.$router六種方法使用示例總結(jié)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • vue攔截器Vue.http.interceptors.push使用詳解

    vue攔截器Vue.http.interceptors.push使用詳解

    這篇文章主要為大家詳細介紹了vue攔截器Vue.http.interceptors.push的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04

最新評論