Pie.vue 1.6 KB
Newer Older
1
<template>
2
  <v-chart :forceFit="true" :height="height" :data="data" :scale="scale" :onClick="handleClick">
3 4 5 6 7 8 9 10 11 12
    <v-tooltip :showTitle="false" dataKey="item*percent"/>
    <v-axis/>
    <v-legend dataKey="item"/>
    <v-pie position="percent" color="item" :v-style="pieStyle" :label="labelConfig"/>
    <v-coord type="theta"/>
  </v-chart>
</template>

<script>
  const DataSet = require('@antv/data-set')
13
  import { ChartEventMixins } from './mixins/ChartMixins'
14 15

  export default {
16 17
    name: 'Pie',
    mixins: [ChartEventMixins],
18 19 20 21 22 23 24 25 26 27 28
    props: {
      title: {
        type: String,
        default: ''
      },
      height: {
        type: Number,
        default: 254
      },
      dataSource: {
        type: Array,
29 30 31 32 33 34 35
        default: () => [
          { item: '示例一', count: 40 },
          { item: '示例二', count: 21 },
          { item: '示例三', count: 17 },
          { item: '示例四', count: 13 },
          { item: '示例五', count: 9 }
        ]
36 37 38 39
      }
    },
    data() {
      return {
40 41 42 43 44
        scale: [{
          dataKey: 'percent',
          min: 0,
          formatter: '.0%'
        }],
45 46 47 48 49 50 51 52 53 54
        pieStyle: {
          stroke: '#fff',
          lineWidth: 1
        },
        labelConfig: ['percent', {
          formatter: (val, item) => {
            return item.point.item + ': ' + val
          }
        }]
      }
55 56 57 58 59 60 61 62 63 64 65 66 67
    },
    computed: {
      data() {
        let dv = new DataSet.View().source(this.dataSource)
        // 计算数据百分比
        dv.transform({
          type: 'percent',
          field: 'count',
          dimension: 'item',
          as: 'percent'
        })
        return dv.rows
      }
68 69 70
    }
  }
</script>