@OSC车队首席老司机 你好,想跟你请教个问题:
我的echarts的容器大小之前用的px,有多个容器,现在想让它自适应大小,开始时用window.onresize=function(){...}不起作用。因为之前做过一个图表,当时的div用的百分比,就想把这个多个div也换成百分比结果居然都加载不出来了。想问一下多个div的自适应怎么做?这是我的代码
for(var i=0;i<seriesarr.length;i++){
myCharts[i] = ec.init(document.getElementById("container" + i));
myChartZooms[i] = ec.init(document.getElementById("newdiv" + i));
var myChartContainer = function () {
myCharts[i].style.width = "container"+i.clientWidth+'px';
myCharts[i].style.height = "container"+i.clientHeight+'px';
myChartZooms[i].style.width = "newdiv"+i.clientWidth+'px';
myChartZooms[i].style.height = "newdiv"+i.clientHeight+'px';
};
myChartContainer();
var option = MyECharts.ChartOptionTemplates.Bar(legendData[i],xdata,xtype,seriesarr[i]);
myChartZooms[i].setOption(option);
myCharts[i].setOption(option); // 为echarts对象加载数据
window.onresize = function () {
for(var i=0;i<myCharts.length;i++){
myCharts[i].resize();
}
for(var i=0;i<myChartZooms.length;i++){
myChartZooms[i].resize();
}
};
之前写的是用window,也没起作用
myCharts[i].style.width = window.innerWidth+'px';
myCharts[i].style.height = window.innerHeight+'px';
报错width,height都不识别,就换成domdiv.clientWidth,domdiv.clientHidth其中的width还有height也不识别。
一个图表,width和height用百分比再加window.onresize()能做出大小随页面的大小而变化来,多个图表时div用百分比时都不能初始化。但是多个图表用px至少图能加载出来就是不能自适应大小。
不好意思,好久没上,给你说一下echarts的父容器的宽和高是不能用百分比的,想要自适应的话,有两种解决思路:1、js控制百分比转换;2、rem自适应布局也是可以的。
我之前装echarts的div长宽都是百分比,父类div长宽是px,加window.onresize()后结果出不来。但是不知道为什么我只把echarts的div的长设置成百分比,其他不变,就长度就可以自适应了..版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。