解决echarts宽度100%变成了100px

原因

外层div设置宽高为100%,在渲染出来的时候变成了100px

这种情况一般都是echart所在的div一开始是display:none,一般出现在以下几种情况:

  1. echats放在了tab中
解决方法(没试过,嫌麻烦):
1、通过js获取外层div的宽高,然后设置给图表容器
2、加 mychart.resize()  

如果用的是elementUI超简单解决办法

el-tabs 有一个属性:lazy,表示标签是否延迟渲染。
设为true,延时加载即可
  1. 首次加载的v-if或者v-show设置为true。

  2. 所在div用了v-show,这种情况要不换成v-if,要不就设置初始值是true。换成v-if可行,但在频繁显示或不显示的时候不适用v-if,所以在试用v-show且初始为false的时候,可以使用resize()

watch:{
	show(v){
		// 在show为true,也就是显示的时候,调用resize 解决100px的问题
		if(v){
		  this.$nextTick(() => this.$refs.chart.instance.resize())
		}
	}
}
  • 8
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值