当前位置: 代码网 > it编程>前端脚本>Vue.js > vue如何解决echarts升级后本地无法启动的问题

vue如何解决echarts升级后本地无法启动的问题

2024年07月02日 Vue.js 我要评论
vue解决echarts升级后本地无法启动1.老项目原来使用的echarts是v4版本,现升级至v5版本首先根据echarts官方文档升级npm install echarts --save然后修改

vue解决echarts升级后本地无法启动

1.老项目原来使用的echarts是v4版本,现升级至v5版本

首先根据echarts官方文档升级

npm install echarts --save

然后修改 引用方式

import * as echarts from 'echarts';

2.完成后使用本地启动

使用npm run serve启动项目,出现报错:

module build failed (from ./node_modules/@vue/cli-plugin-babel/node_modules/babel-loader/lib/index.js):

error: c:\users\src\util\table-sort.js: you gave us a visitor for the node type staticblock but it's not a valid type at verify (c:\users\node_modules\@vue\cli-plugin-babel\node_modules\@babel\traverse\lib\visitors.js:116:13)

3.解决方法

升级@vue\cli-plugin-babel的版本

npm install @vue\cli-plugin-babel

4.我的项目中使用了vue-video-player

升级其它插件后还经常出现找不到样式文件(video.js/dist/video-js.css),此时重装对应版本即可

npm i vue-video-player@5.0.2 

echarts4升级echarts5升级记录

升级后优点,默认样式更好看,动效体验更好。

缺点,容错率降低,需要处理新版不支持的代码

1.y周label的纵向位置调整 负值padding不生效

  • 旧:
axislabel: {
  padding:[-13,0,0,0],
}
  • 新:
axislabel: {
  padding:[-13,0,0,0],
  verticalalign: 'top',
}

2.自定义y轴最大值max与最小值min

  • 旧:min/max写反也能正常使用
  • 新:无法正常使用

3.饼图label位置调整到引导线上方

  • 旧:padding左右双边设为负值
label: {
 normal: {
   textstyle: {
     lineheight: 14,
     fontsize: 12,
     padding: [0, -43]
   }
 }
},
labelline: {
   show: true,
   length: 10,
   length2: 45
 },
  • 新:第二段结束点需自行计算
label: {
 normal: {
   textstyle: {
     lineheight: 14,
     fontsize: 12,
   }
 }
},
labelline: {
   show: true,
   length: 10,
   length2: 0
 },
 labellayout: (params)=> {
   const isleft = params.labelrect.x < canvas.getwidth() / 2;
   const points = params.labellinepoints;
   points[2][0] = isleft ? params.labelrect.x : params.labelrect.x + params.labelrect.width;
   return {
     labellinepoints: points,
   };
 },

4.饼图引导线指向中间

  • 旧:labelline的length设为负值
 labelline: {
  	show: true,
    length: -35,
    length2: -35,
},
  • 新:第二段结束点需自行计算
label: {
   padding: [0, -35],
},
labelline: {
  show: true,
   length: -35,
   length2: 0,
 },
 labellayout: function (params) {
   let center = position[0]//饼图中心x位置
   const points = params.labellinepoints;
   //points line的三个点的x,y位置
   const isleft = points[1][0] <= center;
   points[2][0] = isleft ? points[1][0] + 35 : points[1][0] - 35
   return {
     labellinepoints: points,
   };
 },

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com