echarts超出父容器范围和自适应的解决办法

echarts超出父容器范围和自适应的解决办法,第1张

给echarts图表设置 100% 宽高,父容器动态设置一个宽高时,echarts图表会占满不了父容器或者溢出父容器范围。

产生问题的原因是因为echarts图形只绘制一次,且绘制时自动获取父级大小填写宽度,然后改变容器宽高,导致echarts绑定的元素的宽度并不是最终的宽度,所以造成了获取到的结果并不是想要的。

解决办法是延迟加载,等父容器设置完宽高以后echarts再进行渲染:

CSS有个overflow,为了让显示不下的内容滚动显示,通常会加上:

overflow: scroll;/ 或者 /overflow: auto;

以前我天真地以为,他们的区别仅仅是,一个始终显示滚动条(overflow: scroll

),一个按需显示滚动条(overflow: auto

)。直到遇到了一个 自适应宽度同时自动显示滚动条 的场景,才发现:

overflow: scroll

情况下,内容自动撑开容器的宽度不包括滚动条,相当于滚动条是一个和内容并列显示的组件。

overflow: scroll

而overflow: auto

情况下,内容撑开容器的宽度包括滚动条,即使用whitespace: no-wrap;

撑开容器至正好显示所有内容时,如果有滚动条,则滚动条会覆盖在内容上方,导致内容宽度再次被缩小,然后出现省略号。由此推测渲染顺序:自适应宽度 → 根据高度显示滚动条 → 重新计算内部元素宽度

这里不会再次自适应,因此出现了内容显示不全的情况。

overflow: auto

总结一下就是,如果宽度是由内容自适应撑开的,则overflow: auto;

带来的滚动条会占用内容的一部分宽度,导致内容显示不全。

那么遇到这种情况,最直接的解决办法就是,强制显示滚动条,这也是我在StackOverflow上找到的回答。然而我并不想就这样屈服,而且在Windows上多显示个不必要的滚动条真的很丑,于是我又使用了一个不走寻常路的方法:

动态获取滚动条的宽度:var scrollbarWidth = containeroffsetWidth - containerclientWidth;// 如果没有滚动条则为0// 否则为滚动条宽度

有滚动条的时候需要在内容右侧加个padding

。测试发现,如果直接把padding加在内容元素上,则内容文字显示全了,但是背景在右侧空出了一块。于是换个思路,用一个占位元素来撑开容器,然后再显示真正想要的内容。

占位元素怎么做?其实很简单,就是把当前容器复制一份,但是给它设置:overflow: hidden; height: 0;

,不受滚动条影响宽度,同时高度为0不可见,然后用JavaScript把第1步计算的滚动条宽度作为padding-right

加上去,这样占位元素的宽度就是我们最后想要的容器宽度,可见部分的内容再自适应就完全没有问题了。

不是太明白你的意思,不知道我说的跟你说的是否有关系。

我之前做过根据窗口宽度动态的设置的高度,因为某些特殊原因需要让自适应外层容器,但又不能不设置高度(宽度100%),最后利用 js 动态设置的高度(利用本身的宽高比例计算当前的高度),这里用到了 onload 事件和 onresize 事件 来响应窗口缩放。

希望可以帮到你。

微信小程序d出层全屏轮播可以通过使用第三方组件或自定义组件实现。

第三方组件方案:

1 在小程序开发者工具中搜索“轮播组件”,选择一个合适的第三方组件。

2 将组件的代码复制到小程序中,并进行配置。

3 在需要d出层的页面中引入组件,并设置触发d出层的按钮或事件。

4 在d出层组件中,使用第三方轮播组件实现全屏轮播效果。

自定义组件方案:

1 在d出层组件的wxml文件中添加一个容器,用于显示轮播。

2 在js文件中,获取d出层组件的高度和宽度,计算出的宽度和高度,并将其设置为容器的宽度和高度。

3 在onLoad生命周期函数中,获取需要轮播的列表,并将其存储到data中。

4 在onReady生命周期函数中,调用wxcreateSelectorQuery()方法获取容器的节点,并计算出容器的偏移量。

5 在onShow生命周期函数中,使用wxcreateAnimation()方法创建一个动画对象,并设置动画效果。

6 在动画结束后,使用setTimeout()函数实现定时器,用于轮播。

以上是实现微信小程序d出层全屏轮播的简要步骤,具体实现过程需要根据实际需求进行调整和完善。

以上就是关于echarts超出父容器范围和自适应的解决办法全部的内容,包括:echarts超出父容器范围和自适应的解决办法、overflow之scroll 和 auto、DIV+CSS+JS 容器问题 怎么实现 //移动设备基于屏幕宽度设置容器宽高等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9830784.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-02
下一篇 2023-05-02

发表评论

登录后才能评论

评论列表(0条)

保存