描述:

echarts的容器规定必须定宽高,之前尝试用百分比也失效了。原因是它的容器大小只会在初始加载时获取一次,不论是定死还是百分比,都只会获取一次。这样在拉动页面的时候容器自己改变,但是图表却没有改变。

解决:

为窗口设置监听事件,监听窗口变化,来重新获取echarts的容器大小。

1、首先需要给容器的父容器设置宽高(百分比或者像素都可以)

2、给容器设置百分比的宽高

#chart {
  margin-top: 50px;
  width: 100%;
  height: 75%;
  transform: translateY(-40px);
}

3、在setoption之后设置定时器

   chart.setOption(option);
      setTimeout(function() {
        window.onresize = function() {
          chart.resize();
        };
      });

效果图:

疑惑:

现在还没有办法等比缩放图表容器,想要的结果应该是水平垂直保持居中(可以设置位置百分比)及等比缩放图表。

在搜索后发现,比较常见的等比缩放容器方法是用上下padding代替height,因为padding是根据width取百分比。但是对于echarts而言,如果没有height将无法渲染。

暂时只能做出这样的效果。也许需要在created周期获取到容器的宽度,再通过百分比计算高度return给css,然后在窗口变化函数再加上这个函数,更改容器的height。有时间再尝试。

 

 

 

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐