利用CSS的Sass预处理器(框架)来制作居中效果
注意!上面代码中的 #{0 0} 实际上一种容错措施,如果直接使用 0 0 的话,Sass 解析器会尝试进行数值运算(在这里会自动进行 0 -($height / 2) 的数学运算),进而导致我们得到 margin: mt 0 ml; 而不是想要得到的 margin: mt 0 0 ml;。 基本的功能实现后,我们还可以添加更多的特性,比如添加 @support 来检查浏览器对 CSS transform 的支持度,进而可以根据 CSS transform 的支持度输出相应的条件样式。此外,我们还可以更严谨地去测试出入的参数是否是有效数值…… 使用 Flexbox 看到 Flexbox 这个词是不是就很兴奋啊,少年!确实,使用 Flexbox 确实是最简单的方式,它和前面方法主要的差别在于,使用 Flexbox 需要为父容器设定相关样式,而使用前面的方法则主要是为子元素设定相关样式(当然,父容器需要被设定为除 static 之外的任意 position)。 使用 Flexbox 实现子元素的居中效果,只需三行代码:
CSS Code复制内容到剪贴板
@mixin center-children { display: flex; justify-content: center; align-items: center; } 由于 Flexbox 还是比较新的属性,那么添加上相关的浏览器前缀的话,会让它拥有更广泛的兼容性。
CSS Code复制内容到剪贴板
.parent { @include center-children; } 正如你料想的那样,就这么简单我们就实现了:
CSS Code复制内容到剪贴板
.parent { display: flex; justify-content: center; align-items: center; } 总结 我们就想要一个简短的 mixin 让元素在父容器中居中,我们做到了,而且做的更好。它不仅仅简单易用无副作用,而且提供了良好的开发接口。 (编辑:上饶站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |