Accessing Canvas Ref and chartInstance
The Chart.js chartInstance
and canvasRef
are accessible by the component's reference using ref
. It is also passed in events (chart-render
and chart-update
)
<template>
<DoughnutChart ref="doughnutRef" :chartData="testData" @chart:render="handleChartRender" />
</template>
<script>
import { shuffle } from 'lodash';
import { computed, defineComponent, ref, onMounted } from 'vue';
import { DoughnutChart } from 'vue-chart-3';
export default defineComponent({
name: 'Home',
components: { DoughnutChart },
setup() {
const doughnutRef = ref();
// ....
onMounted(() => {
console.log(doughnutRef.value.chartInstance);
doughnutRef.value.chartInstance.toBase64Image();
});
// Chart instance is accessible on events too
function handleChartRender(chart) {
console.log(chart);
}
return { shuffleData, testData, doughnutRef, handleChartRender };
},
});
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29