问题很简单:
>我页面的主要部分是一个正方形,应以所有屏幕尺寸和方向显示在屏幕中央
>广场应该有效地使用屏幕,并且尽可能大,而无需滚动
>没有滚动条,没有固定大小,没有溢出隐藏,没有Javascript.
>鼓励FlexBox.
这是页面在横向或纵向浏览器中的外观:
这是一个CodePen作为起点.
最佳答案
这是我实现最终目标的尝试.
关键是对方框的宽度和高度属性使用vmin
viewport percentage length:
.body,.square {
display: flex;
align-items: center;
justify-content: center;
}
.body {
min-height: 100vh;
}
.square {
width: 100vmin;
height: 100vmin;
}
(为简洁起见,省略了供应商前缀,请检查demo中的“编译视图”).