最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

vue集成chart.js的实现方法

来源:懂视网 责编:小采 时间:2020-11-27 21:52:07
文档

vue集成chart.js的实现方法

vue集成chart.js的实现方法:指令 该指令的作用是dom渲染后触发,因为非vue的插件有的是dom必须存在的情况下才可以执行 Vue.directive('loaded-callback', { inserted: function (el, binding, vnode) { binding.value(el, binding, vnode)
推荐度:
导读vue集成chart.js的实现方法:指令 该指令的作用是dom渲染后触发,因为非vue的插件有的是dom必须存在的情况下才可以执行 Vue.directive('loaded-callback', { inserted: function (el, binding, vnode) { binding.value(el, binding, vnode)

指令

该指令的作用是dom渲染后触发,因为非vue的插件有的是dom必须存在的情况下才可以执行

Vue.directive('loaded-callback', {
 inserted: function (el, binding, vnode) {
 binding.value(el, binding, vnode)
 }
})

安装chartjs

npm install chart.js --save

chartjs 组件

<template>
 <canvas refs="chartcanvas" v-loaded-callback="setCanvas"></canvas>
</template>
<script type="text/javascript">
require('chart.js')
export default{
 name: 'components-base-chartjs',
 props: {
 'data': {},
 'options': {},
 'type': {}
 },
 data:function(){
 return {
 canvas: null,
 chart: null
 }
 },
 watch:{
 canvas: function () { // chart对象生成时触发
 this.initChart()
 },
 data: {
 handler: function () { // 数据变化时触发
 this.updateChart()
 },
 deep: true
 }
 },
 destoryed:function (){
 if(this.cahrt){
 this.cahrt.destroy()
 }
 },
 computed: {
 currentOptions: function (){
 var options = {}
 if(this.options){ // 加载自定义配置参数
 for(var i in this.options){
 options[i] = this.options[i]
 }
 }
 return options
 }
 },
 methods: {
 setCanvas: function(el){ // dom生成时触发
 this.canvas = el
 },
 initChart: function () { // 更新chart结果
 if(this.data && this.currentOptions){ // 保证参数的存在
 this.chart = new Chart(this.canvas.getContext('2d'),{
 type: this.type,
 data: this.data,
 options: this.currentOptions
 })
 }
 },
 updateChart: function () { // 更新chart结果
 this.chart.data = JSON.parse(JSON.stringify(this.data))
 this.chart.update()
 }
 }
}
</script>

用法

<chartjs :options="options" type="pie" :data="data"></chartjs>

options 及数据结构

请跳转

文档

vue集成chart.js的实现方法

vue集成chart.js的实现方法:指令 该指令的作用是dom渲染后触发,因为非vue的插件有的是dom必须存在的情况下才可以执行 Vue.directive('loaded-callback', { inserted: function (el, binding, vnode) { binding.value(el, binding, vnode)
推荐度:
标签: 使用 VUE js
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top