• 问题
  • 分析
  • 解决办法

问题

先看一下正常的情况

再看一下显示不全的情况

所有的数据都是从后台取的,也就是说动态变化的,一开始的时候数据量不大不会出现问题,后面y轴的值越来越大的时候就出现了这个显示不全的情况。


分析

先贴一下页面代码

HTML

<div class="row-wrapper"><div class="div-flex" style="text-align:center"><div class="chart-tab selected" id="chart-tab0">最近30天</div><div class="chart-tab" id="chart-tab1">最近15周</div><div class="chart-tab" id="chart-tab2" style="border-right: 1px #dcdcdc solid;">最近12个月</div></div><div id="chart-line"></div>
</div>

CSS

.row-wrapper {padding: 10px 15px;border-top: 8px #eee solid;font-size: 15px;color: #737373;
}.chart-tab {flex: 1;border-top: 1px #dcdcdc solid;border-left: 1px #dcdcdc solid;border-top-left-radius: 5px;border-top-right-radius: 5px;
}.div-flex {display: -webkit-box;display: -webkit-flex;display: flex;
}#chart-line {height: 26rem;padding-left: 14px;padding-top: 10px;border: 1px #dcdcdc solid;
}.selected {background-color: #EAEAEA;
}

JS(这里只贴跟折线图有关的部分)

var lineChart = echarts.init(document.getElementById('chart-line'));// 折线图配置
option = {tooltip: {trigger: 'axis',hideDelay: '300'},xAxis: {show: false,type: 'category',data: [1, 2, 3, 4, 5, 6, 7],axisTick: {inside: true,alignWithLabel: true}},yAxis: {type: 'value',name: '营业额(元)',axisTick: {inside: true},scale: true},series: [{name: '营业额',type: 'line',data: [1100000, 2000000, 450000, 1370000, 1200000, 4030000, 2350000], // 因为是要分析的是前端问题,这里我就直接写一组很大的数据了,不管跟后台交互部分lineStyle: {normal: {color: '#82c26b'}},itemStyle: {normal: {color: '#82c26b'}}}]
};lineChart.setOption(option);

然后页面运行的时候生成的html是这样的

可以看到 id=chart-line 的 div 是我定义的,而它里面多了两个元素,一个 div 和一个 canvas。这两个就是 Echarts 运行之后添加上去的,其中 canvas 就是图表本身,外层的 div 是一个装它的容器。
于是我尝试一下修改这几个元素的 width、margin、padding,发现……没用。

看下图

修改了marginpadding 的之后在 chrome的debug模式下看 canvas 是这样的,能看到其实y轴文字部分还是在content(蓝色部分)里面的,所以就能明白为什么修改 canvasmargin、padding 不会起作用了。
于是能得出结论,这是 canvas 绘图的时候就定了的,所以要通过修改传给 echarts 的参数来修改。

好吧,那咱们就去官网看API咯……


解决办法

官网在此:http://echarts.baidu.com/

我们要看的是配置项的部分:http://echarts.baidu.com/option.html#title

可以改的地方有下面几个:

  1. yAxis.axisLabel.margin:刻度标签与轴线之间的距离。默认值是8,可以改小一点。不过本来的值已经很小了,这个没多大作用。
  2. yAxis.axisLabel.formatter:刻度标签的内容格式器,支持字符串模板和回调函数两种形式。比如可以设置太长了换行之类的。
  3. grid.left:grid 组件离容器左侧的距离。默认值是10%。

最后的代码如下。这里就只列出修改了的部分了,比原来添加了 grid.leftyAxis.axisLabel

option = {...yAxis: {type: 'value',name: '营业额(元)',axisTick: {inside: true},scale: true,axisLabel: {margin: 2,formatter: function (value, index) {if (value >= 10000 && value < 10000000) {value = value / 10000 + "万";} else if (value >= 10000000) {value = value / 10000000 + "千万";}return value;}},},grid: {left: 35},...
};

最终效果还行。。


PS:最后忍不住要吐槽,这几个配置项找了我老半天啊囧

Echarts 折线图y轴标签值太长时显示不全的解决办法相关推荐

  1. echarts折线图不显示y轴值_Echarts 折线图y轴标签值太长时显示不全的解决办法

    问题 先看一下正常的情况 再看一下显示不全的情况 所有的数据都是从后台取的,也就是说动态变化的,一开始的时候数据量不大不会出现问题,后面y轴的值越来越大的时候就出现了这个显示不全的情况. 分析 先贴一 ...

  2. Echarts中折线图Y轴数据值太长显示不全-解决办法

    正常状态 不全的情况 所有的数据都是从后台取的,也就是说动态变化的,一开始的时候数据量不大不会出现问题,后面y轴的值越来越大的时候就出现了这个显示不全的情况 代码 <div id="c ...

  3. echarts折线图y轴根据数值自动_Python matplotlib 绘制双Y轴曲线图的示例代码

    双X轴的 可以理解为共享y轴 ax1=ax.twiny() ax1=plt.twiny() 双Y轴的 可以理解为共享x轴 ax1=ax.twinx() ax1=plt.twinx() 自动生成一个例子 ...

  4. echarts折线图y轴根据数值自动_R语言基础绘图教程——第3章:折线图和带状图...

    教程代码和文件,关注本公众号,后台回复:R语言基础绘图代码 R基础教程可先阅读:R语言编程基础第一篇:语法基础 利用plot()绘制 在上一章中我们讲过plot()绘图的基本结构,主要通过type参数 ...

  5. echarts折线图点击x值动态高亮且显示tooltip

    预期效果:提示框显示时,相应的x坐标月份高亮(蓝色),同时提示框显示. 实现流程: 1.设置一个变量axisValue用于接收选中x值,当横轴值等于选中的axisValue时,设置蓝色 axisLab ...

  6. Echarts实现折线图Y轴不等距百分比(最终解决方案)

    Echarts实现折线图Y轴不等距百分比(最终解决方案-上集) 出现背景 解决思路 总结 附加 出现背景   最近公司有一个需求,主要是想展示近7日产品的一个良品率(百分率制).但是呢,基本上每天这个 ...

  7. echarts折线图x轴不从0开始

    1.问题描述 使用折线图展示相关数量时,发现在x轴上,折线不是从0开始的,结束的时候也不是在x最后 .如下图所示: 2.解决问题 在echarts图表x轴配置信息中有一个属性来控制是不是从0开始的. ...

  8. echarts折线图曲线,每个值上面添加小圆点或者小圆圈

    在折线图中,我们可能会在每个数值上面加小圆点或者小圆圈,只需要在series中加symbol即可,以下是两种效果,当symbol值为none的时候,则没有小圆点或者小圆圈,当值为false或者' '时 ...

  9. echarts 折线图 x轴为时间轴

    因为最近项目做监控图,需要折线图的x轴是时间轴,之前不了解,解决以后来写个总结吧. echart 中的折线图,x轴的类型,官方文档为: 其他类型,官网有例子,这里我只写一下time类型的 结果: 源代 ...

最新文章

  1. pytorch中的transpose()
  2. LeetCode实战:缺失的第一个正数
  3. 4、Python —— 函数
  4. 如何评估AI在医学影像识别中的应用效果?
  5. 2021-05-07 matlab中的addpath用法
  6. 创建函数查找上级_一文秒懂JavaScript中对象的7种创建方式
  7. 宝塔安装sqlserver_宝塔面板for windows 连接mssql2008
  8. 设置电子围栏 高德地图_地理围栏-辅助功能-开发指南-Android 定位SDK | 高德地图API...
  9. 物联网安全有哪些注意事项
  10. java.lang.IllegalStateException: UT010019: Response already commited
  11. CentOS 5.X MySQL5.5.35 编译的bug
  12. Integer的比较
  13. 看书必备:40个全球免费开放电子图书馆
  14. 【大数据】大数据-实时统计分析-方案选型
  15. 第12课:生活中的构建模式——想要车还是庄园
  16. MATLAB写入文件的操作
  17. MySQL从删库到跑路: 入门篇
  18. 写一个用矩形法求定积分的通用函数,分别求: ∫(0,1) sinxdx , ∫(0,1)cosxdx , ∫(0,1)e^xdx 。
  19. 第一次安装使用rsync服务进行两台服务器之间的文件同步,并排查客户端到服务端网络不通的问题。
  20. CHAR 和 VARCHAR 的区别?

热门文章

  1. 南水北调新进展: 引江补汉工程加快做好开工准备
  2. 在Cordova中自定义AndroidTest(Instrumented Unit Test)
  3. python 图形界面“诈金花”游戏,更新了!附完整代码
  4. 一篇短文让你了解如何简化「内测托管」过程
  5. 推荐一款神器:在浏览器中运行 VS Code,随时随地写代码
  6. 03 汽车以太网如何影响ECU和传感器设计
  7. 一秒学会给自己的PDF文档加密!
  8. es6深入浅出学习笔记
  9. VC6 向 VC9 移植时常见BUG
  10. 用计算机管理系统分区,图文详解win10只有c盘怎么分区