echarts 字体自适应的方法(使用rem)

本文介绍了一种使用rem单位和屏幕宽度动态调整字体大小的方法。通过计算屏幕宽度与基准宽度的比例,实现不同屏幕尺寸下的字体自适应。适用于echarts等图表组件,确保在窗口大小变化时字体实时更新。

采用rem为单位,根据屏幕的宽度调整html的font-size。

获取屏幕宽度并计算比例:

function fontSize(res){
	const clientWidth = window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth;
	if (!clientWidth) return;
	let fontSize = clientWidth / 1920;
	return res*fontSize;
}

在需要设置字体的地方可以这样写,
如在1920屏宽下字体设置为12px,就可以传入12给fontSize

tooltip : {
	trigger: 'axis',
	textStyle:{
		fontSize: fontSize(12),
	}
},

当浏览器窗口发生改变的时候,需要重绘图表,才能实现实时改变echarts字体

window.addEventListener('resize',()=>{
	this.refreshChart();
})
// vue
setFontOption() {
	this.chart.setOption({
		tooltip : {
			textStyle:{
				fontSize: fontSize(12),
			}
		}
	})
},
refreshChart() {
    if (!this.chart) return;
    this.chart.resize();
	this.setFontOption();
}
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值