这篇文章发布于 2023年05月31日,星期三,00:26,归类于 CSS相关。 阅读 23789 次, 今日 10 次 13 条评论
by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=10858 鑫空间-鑫生活
本文欢迎分享与聚合,全文转载就不必了,尊重版权,圈子就这么大,若急用可以联系授权。
一、一言以蔽之
CSS margin-trim
属性设置在容器元素上,可以让子元素(需边缘接触)的margin
设置计算值变成0
。
二、语法、演示
语法如下示意:
margin-trim: none; margin-trim: block; margin-trim: block-start; margin-trim: block-end; margin-trim: inline; margin-trim: inline-start; margin-trim: inline-end;
仅支持逻辑CSS属性值,表示哪个方位的margin需要修剪。
inline表示内联元素的排版方向,也就是水平,block表示块级元素的排版方向,自然表示垂直了,也就是上下。
使用示意
margin-trim
使用在设置了margin的列表中,或者不断重复的标签项中。
举个例子,一个容器中有若干的列表项。
每个列表之间会有一些上下间距。
这个间距我们常常会使用margin进行设置,例如:
<div class="box"> <div class="item">中国航天一往无前</div> ... <div class="item">Angelababy红毯从来没有失手过</div> </div>
.box { border: 1px solid #999; padding: .75rem; } .item { ... margin-block: .75rem; }
此时,第一个元素的上部和最后一个元素的下部的空白间距就会过大,如下结果所示:
在以前,我们往往需要使用:first-child或:last-child重置margin属性值。
.item:first-child { margin-top: 0; } .item:last-child { margin-bottom: 0; }
现在呢,就我个人而言,都是使用Grid布局解决这个问题。
例如:
.box { display: grid; /* 子项就不设置margin属性了 */ gap: .75rem; }
也非常nice,除了尺寸(高宽都会)这块,可能会有意料之外的渲染外,其他都很OK。
未来呢,可能就会使用 margin-trim
属性,不改变容器原本的display状态,也不会改变子项的尺寸模型,会更友好些。
使用也很简单:
.box { margin-trim: block; }
寥寥一行CSS代码就可以解决问题了。
此时,列表的渲染效果就会是下面这般(截自Safari 16.5,我macOS特意升了个级Ventura版本,下载了11.79G升级包):
眼见为实,如果您手上有Safari16.4及其以上版本浏览器,可以狠狠地点击这里:margin-trim修剪边缘间距列表布局demo
margin-trim: inline的奇怪表现
如果我给列表元素同时设置水平margin,并且给容器元素设置margin-trim:inline
,出现了意料之外的渲染效果,那就是只有最后一个元素的水平margin被修剪了。
如下截图所示:
着实奇怪,不是全部的水平margin消失,也不是首尾两个元素,而是最后一个。
难道跟排版方向有关的吗?
于是我又试了flex布局,让子项水平排列。
.box { display: flex; margin-trim: inline; } .item { margin: .75rem; }
结果果然这般,如果水平排列,同时子项在水平方向有margin设置,第一个和最后一个元素和容器接触方向的margin就会消失,示意图如下:
其实,按照我的理解,margin-trim应该是只要边缘接触,margin就要消失,而不仅仅局限于首尾元素上,这样,此属性的应用潜力才会更大呀。
比方说下图这样的布局场景,因为所有的标签都有个margin-right,导致明明空间足够,但是标签还是换到了下面:
要是margin-trim针对的是任意子元素,那上面的经典难题就可以轻松解决,可惜,并不支持。😑
兼容性
目前margin-trim
属性仅Safari支持,正式应用于生产环境还需要写时日。
所以,此属性大家暂时了解下即可。
三、扯淡碎碎念时间
1. 读《绍宋》有感
《绍宋》加入起点阅读的书架很久了,一开始都是追漫画(起点APP内有),漫画画得确实厉害,但更新太慢,正看到关键,没了,屡次如此,便忍不住开始追文,一口气看了很多章,感触颇深。
- 作者牛,功力了得,尤其是细节和代入感;
- 自己起点那本小说犯了个致命错误,定位不准,自己无需刻意往爽文套路上靠,应该追寻本心,写自己擅长的;
- 学到了很多历史知识;
- 颇有职场启发,例如成为怎样的员工,做怎样的自己,技术与政治等。
2. 周日运动计划
隔壁小区有个免费开放的篮球场,基建很不错,周日上午去去拍了1个小时篮球,感觉不错,自己运动的同时可以和小朋友一起玩耍,父慈子孝,以后每周都会如此。
3. Android手机换了
因为开发需要,自己有个iPhone,还有个Android机。
数月前Android手机在钓鱼的时候不甚落水,结果信号一直不好,上周六忍无可忍,给换了,同牌子,刚上市的一款,据说拍照1亿像素,但是这拍照质量……只能说,对得起这个价格吧。😂
本文为原创文章,欢迎分享,勿全文转载,如果实在喜欢,可收藏,永不过期,且会及时更新知识点及修正错误,阅读体验也更好。
本文地址:https://www.zhangxinxu.com/wordpress/?p=10858
(本篇完)
- CSS margin-inline和margin-block区别是什么? (0.680)
- Tips: 使用CSS逻辑属性简化我们的书写 (0.560)
- CSS columns轻松实现两端对齐布局效果 (0.320)
- CSS gap属性进化史 (0.320)
- 介绍2022最期待且已正式支持的CSS container容器查询 (0.240)
- css margin的相关属性,问题及应用 (0.120)
- absolute绝对定位的非绝对定位用法 (0.120)
- CSS 相对/绝对(relative/absolute)定位系列(二) (0.120)
- CSS 相对/绝对(relative/absolute)定位系列(三) (0.120)
- CSS 相对/绝对(relative/absolute)定位系列(四) (0.120)
旭哥,最近打开你的博客,第一页的分页数据最新的几篇老是出不来,是为啥呀~
既然旭哥看绍宋,那我要推荐:《宰执天下》《官居一品》
好的~
这一亿像素效果也不怎么样嘛。应该是Realme吧。
“下图这样的布局场景,因为所有的标签都有个margin-right,导致明明空间足够,但是标签还是换到了下面”
— 能请假这种经典场景最优雅的解决方案吗
没有什么优雅的方法~
有不优雅的解决方案吗
flex 布局, 然后用 gap 做间隔
好的,谢谢
可以使用 flex 布局和 flex-wrap、gap
方案一:使用 flex 布局和 flex-wrap、gap;
方案二:可以套一层 div 设置 width: calc(100% + var(–gap)),多出一点间隙的距离,最外层容器设置 overflow: hidden
读完本篇文章很想看看《绍宋》
自从咩了之后,我就很惜命再也没熬到12点之后了。虽然一次次症状轻,但是一次次带来的后遗症也明显感觉出。大佬注意身体阿