首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

overflow和动态计算高度

首先是MDN:https://developer.mozilla.org/zh-CN/docs/Web/CSS/overflow 其中对overflow进行了描述: CSS 属性 overflow 定义当一个元素的内容太大而无法适应...重点在这里: 为使 overflow有效果,块级容器必须有一个指定的高度(height或者max-height)或者将white-space设置为nowrap。...那问题来了,我这里有一个折叠面板 我希望这里多个折叠面板每一项的头部都能显示在页面中,并且其子项能够适应屏幕高度和折叠情况变化 为了实现上面的效果,我们需要在每一个折叠面板子项中设置overflow-y...:auto,然后给其设置height或者max-height 我们知道css中有个计算函数calc可以计算我们的高度,这里的卡片为了保证屏幕自适应,可以用其计算出我们这里所需的高度为100vh(屏幕可视区域高度...)-其余占位高度(比如卡片上下的留白,卡片头部的高度等),最后需要除以这里的折叠面板数量3,但有个问题,这里不一定是3个,有可能是多个,使用vue动态渲染的,这样的话我们就只能在vue标签上指定高度 例如

1.3K20

CSS 奇技淫巧:动态高度过渡动画

每次展开的时候,过渡展开到容器本身的高度即可。 查看规范,究其原因,在于 CSS transtion 不支持元素的高度为 auto 的变化。...但是,我们又希望能够做到动态高度的过渡转换,是不是就没有办法了么? 巧用 max-height 适配动态高度 嘿嘿,这里有一个非常有意思的小技巧。...既然不支持 height: auto,那我们就另辟蹊径,利用 max-height 的特性来做到动态高度的伸缩。...但是这里不能设置的太高,最高是贴近最大的使用高度即可,后面会聊到为什么。 由于 max-height 只是限制文本的最大高度,当容器的实际高度没有达到限制的最大高度,将不会继续变高,看看效果: ?...综上,方法是好方法,但是具体使用的时候要需要具体分析。

1.1K10
您找到你想要的搜索结果了吗?
是的
没有找到

CSS 也能实现 if 判断?实现动态高度下的不同样式展现

最近在群里,有个小伙伴问了这么一道很有趣的问题: CSS 能否实现,容器再某个高度下是某种表现,一旦超出某个高度,则额外展示另外一些内容 为了简化实际效果,我们看这么一张示意效果图: 可以看到,当容器高度没有超过某一个值时...这个效果在很多场景都会出现,可以算是一个高频场景,那么在今天,我们能否不使用 JavaScript,仅仅凭借 CSS 实现类似于这样的功能呢?...别忘了,CSS 中,还有几个非常有意思的数学函数:min()、max()、clamp(),它们可以有效限定动态值在某个范围之内!...不太了解的,可以看看这篇 现代 CSS 解决方案:CSS 数学函数 利用 clamp(),我们可以限定计算值的最大最小范围,在这个场景下,我们可以限制 bottom 的最大值为 10px: .g-content...我们可以清楚的看到,当我们往下拖动容器变高的时候,箭头元素是逐渐慢慢向上出现,而不是突然在某一个高度下,直接出现,所以在实际使用中,会出现这种 ICON 只出现了一半的尴尬场景: 但是,莫慌!

25450

动态生成DOM元素的高度及行数获取与计算方法

背景 在开发IM的项目过程中,经常会有出现一些需要计算DOM高度,然后超出若干行隐藏等需求。很多时候,需要计算高度的DOM元素都是动态生成的,我们无法在数据渲染前获取到它的高度。...但是,如果我们需要获取到这段在内存中未渲染的动态文本,也能够通过如下几个方法。...获取高度后页面行数计算将在后面统一讲解。 优点 此方案通过直接在实际场景的页面上渲染后进行高度计算,因此计算精准,不存在任何偏差。...为什么我们不使用display:none来实现上述效果呢?因为在使用了该属性后,window.getComputedStyle获取的高度将变为auto。...总结 获取动态元素的高度一直都是IM项目中的一个重要需求,自己在这个方面也踩了许多坑,因此写了这一篇博客来进行记录,同时其他人如果看到了也可以避免一些常见问题。

3.7K30

css高度坍塌与清除浮动

高度坍塌的原因 在文档流中,父元素的高度默认是被子元素撑开的,也就是子元素多高,父元素就多高....但是当为子元素设置浮动以后,子元素会完全脱离文档流,此时将会导致子元素无法撑起父元素的高度,导致父元素的高度塌陷.由于父元素的高度塌陷了,则父元素下的所有元素都会向上移动,这样将会导致页面布局混乱....解决办法:经常使用的清除浮动的方案: clearfix方案【原理:就是在这个父元素的最后创建一个伪元素after。...可以达到清除浮动的效果 与上一节方法1-使用clear清除浮动-异曲同工*/ .clearfix:after { /* 如果要使用伪元素...可以达到清除浮动的效果 与上一节方法1-使用clear清除浮动-异曲同工*/ .clearfix:after { /* 如果要使用伪元素

1.8K50

css div高度设置100%如何生效!

,如果此时 height:100%可以计算,则 子元素应该也是 192 像素。...但是,父元素 height 值是 auto,岂不是现在高度要从原来的 192 像素变成 384 像素,然后 height:100%的子元素高度又要变成 384 像素,父元素高度 又双倍……死循环了!...那问题又来了:为何宽度支持,高度就不支持呢?规范中其实给出了答案。如果包含 块的高度没有显式指定(即高度由内容决定),并且该元素不是绝对定位,则计算值为 auto。...要知道,auto 和百分比计算,肯定是算 不了的: 'auto' * 100/100 = NaN 但是,宽度的解释却是:如果包含块的宽度取决于该元素的宽度,那么产生的布局在 CSS 2.1 中是未定义的...这里和高度的规范定义就区别明显了,高度明确了就是 auto, 高度百分比计算自然无果,width 却没有这样的说法,因此,就按照包含块真实的计算值作为 百分比计算的基数。

5.6K00

动态的 iframe 内容高度自适应

使用iframe加载其他页面的时候,需要自适应iframe的高度 这里加载了两个不同内容高度的页面至iframe中 1....有滚动条,可以看到iframe并不会因为内容高度自动撑开 2....内容长这样,但可以看到,高度定死了,没有自适应 3....可以发现,高度虽然能自适应,不过只支持高度了“从小到大”的自适应 如iframe2的内容比iframe1的高,后者动态加载出前者能自适应,但前者动态加载出后者就不行了,这种高度减小不了 最后的解决办法是...在onload事件中动态设置高度为body高度之前,先将原高度还原为auto或空值 可以用setTimeout(fn,0)将高度设置放到下一轮事件循环中执行,或者在 onbeforeunload 事件中先把高度设置为

6.5K51

LinearLayout.onMesaure-计算LinearLayout的高度

resolveSizeAndState(heightSize, heightMeasureSpec, 0); heightSize = heightSizeAndState & MEASURED_SIZE_MASK; 以上代码为计算...LinearLayout总高度的代码 判断useLargestChild,如果标识位为true的话,说明这是使用最大的子View的高度来作为自己的高度,从判断可以看出,只有当heightMode不是MeasureSpec.EXACTLY...的时候,才会走这个判断,意味着,如果不是EXACTLY的话,那么LinearLayout就是可变的了 接着就将mTotalLength置为0,会遍历所有的子View将最大子View的高度赋给mTotalLength...变量,也就是用最大高度的子View来做自己的高度 将子View的高度再加上上下的padding,获得所需要的总高度 判断background中Drawable的高度和所需总高度比,拿最大的那个做为所需要的总高度...通过resolveSizeAndState来获取LinearLayout的高度以及状态 通过位运算获取高度

64310
领券