echarts柱状图x轴文字换行_echarts图表X轴文字过长解决解决方案:根据文字长度自动旋转...

Echarts 标签中文本内容太长的时候怎么办 ?

关于这个问题搜索一下,有很多解决方案。无非就是 省略(间隔显示)、旋转文字方向、竖排展示

前面两种解决方案,就是echarts暴露的:

{

axisLabel: {

interval: 0,//如果设置为 1,表示『隔一个标签显示一个标签』,如果值为 2,表示隔两个标签显示一个标签,以此类推。

rotate: '45',// 刻度标签旋转的角度,在类目轴的类目标签显示不下的时候可以通过旋转防止标签之间重叠。

},

};

用法看官方文档:

网上有关的设置也看了下,几乎大同小异,比如:

如何更加标签文字的总长度自动采取调整策略

对于固定模式的图标,我们直接设置 竖排展示或者旋转就可了。但是对于图表类平台,如何控制 X轴文字自适应显示呢

这就需要我们去计算 x轴标签文字的长度,然后去匹配图表宽度,然后才去旋转策略去显示

如何计算字符串在浏览器中显示的宽度

这个有两种方法,一个是直接计算字符串,第二个是canvas里面计算

通过文本计算字符串的宽度

/**

* @description 计算字符串在浏览器中显示的宽度

* @author andyzhou

* @create andyzhou

* @update 1/27/21 by andyzhou

* @param text {string|number}

* @param fontSize {number}

* @return {number}

*/

export default function computedTextWidth(text, fontSize = 14) {

let span = document.getElementById('computedTextWidth');

if (!span) {

span = document.createElement('span');

span.id = 'computedTextWidth';

span.style.cssText = 'visibility:hidden;position: absolute;left: -999em;top:-999em;';

document.body.appendChild(span);

}

span.style.fontSize = `${fontSize}px`;

span.innerHTML = text;

return span.offsetWidth;

};

这个方法可以共用,我就是直接采用这个

canvas里面计算文本宽度

在canvas绘图环境中,measureText()方法可以度量字体的宽度。measureText()方法返回了一个包含width属性的TextMetrics对象,后期我们会使用这个方法实现文本编辑器。

/**

* @description 计算字符串在浏览器中显示的宽度

* @author andyzhou

* @create andyzhou

* @update 1/27/21 by andyzhou

* @param text {string|number}

* @param fontSize {number}

* @return {number}

*/

export default function computedTextWidth2(text, fontSize = 14) {

let canvas = document.getElementById('computedTextWidth');

if (!canvas) {

canvas = document.createElement('canvas');

canvas.id = 'computedTextWidth';

canvas.style.cssText = 'visibility:hidden;position: absolute;left: -999em;top:-999em;';

document.body.appendChild(canvas);

}

const context = canvas.getContext('2d');

context.font = `${fontSize}px`;

context.fillText(text, 0, 0);

return context.measureText(text).width;

};

推荐采用这个函数

vue组件里面 echart坐标轴自适应文本

// 计算x周文本总宽度

const textWidth = categoryData.reduce((value, current) => value + computedTextWidth(current), 0);

// 计算组件容器宽度

const  width = this.$parent.$el.clientWidth;

const rotate = width - 50 > textWidth ? 0 : 40;

this.options.xAxis =  {

type: 'category',

axisLabel: {

interval: 0,

rotate,

},

axisTick: { show: false },

data: categoryData,

};

其他调整,原理和这个差不都,就不赘述了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值