html - 响应式调整父级内的 HTML div 大小,包括信箱和邮筒,仅 CSS
问题描述
给定一个可以调整垂直和水平大小的父 HTML div 元素,我希望子 div 保持纵横比(例如,16:9),居中并受父级边缘的约束。请不要JS。
单独使用 CSS 是否可行?(顶部“较宽”的父图像示例是pillarbox,底部“较窄”是letterbox。)
注意:在大多数情况下,父级会小于实际的浏览器视口,因此不要根据浏览器视口的宽度或高度来判断您的答案(例如)。这应该能够在任何给定的父/子大小下独立存在。
解决方案
如果您愿意为此使用 iframe,我有一个创造性的解决方案。
字体大小可以相对于视口大小动态更改。您想要调整容器而不是窗口的大小,因此为了使其工作,我们必须使用具有自己的视口的 iframe 包装所有内容,并调整 iframe 的大小。
这个想法是使用 em 单位设置元素的宽度和高度,并动态设置字体大小。
我们有 2 个场景,一个更宽的容器或一个更高的容器,为了将它分开,我们将使用媒体查询:
max-aspect-ratio: 16/9
1.更高的容器
由于我们希望 div 保持 16:9 的比例,我们将 div 的尺寸设置为
width: 16em;
height: 9em;
为了让它占据 100% 的宽度,我们将字体大小设置为 100/9 = 11.111
font-size: 11.111vh
2.更宽的容器
一旦我们的媒体查询启动并且容器更宽,我们将根据视口宽度更改字体大小,并且我们希望它采用 100% 的宽度,所以 -> 100/16 = 6.25
@media (max-aspect-ratio: 16/9) {
.ratio-wrapper {
font-size: 6.25vw;
}
}
现在我们可以为内容添加另一个 div 并设置我们想要的任何字体大小。
var iframe = document.getElementById('iframe');
var content = "<html>" +
"<head>" +
"<style>" +
"body," +
"html {" +
" padding: 0;" +
" margin: 0;" +
"}" +
".ratio-wrapper {" +
" background-color: #bada55;" +
" font-size: 11.111vh;" +
" width: 16em;" +
" height: 9em;" +
"}" +
".center {" +
" width: 100%;" +
" height: 100%;" +
" display: flex;" +
" justify-content: center;" +
" align-items: center;" +
"}" +
".content {" +
" height: 100%;" +
" display: flex;" +
" justify-content: center;" +
" align-items: center;" +
" font-size: 20px;" +
"}" +
"@media (max-aspect-ratio: 16/9) {" +
" .ratio-wrapper {" +
" font-size: 6.25vw;" +
" }" +
"}" +
"</style>" +
"</head>" +
"<body>" +
"<div class='center'>" +
"<div class='ratio-wrapper'>" +
"<div class='content'>It Works!</div>" +
"</div>" +
"</div>" +
"</body>" +
"</html>";
iframe.src = 'data:text/html,' + encodeURIComponent(content);
.cont {
width: 300px;
height: 300px;
border: 1px solid black;
resize: both;
overflow: hidden;
padding: 0;
margin: 0;
}
<iframe id="iframe" src="about:blank" class="cont" scrolling="no"></iframe>
请注意,我只是使用 JS 将内容添加到 iframe,所以它可以在这里工作,您只需为您的内部内容设置一个 href,不需要 JS。我使 iframe 可调整大小,因此您可以轻松地使用它,或者您可以给它一个响应大小,它也可以。
推荐阅读
- c++ - CodeChef 和 CodeForces 上的最小硬币找零问题(动态编程实现)超过了时间限制
- haskell - Haskell - 列表列表中元素组合的列表
- javascript - 如何使用 VueJS 将数据从 Java servlet 正确传递到 HTML 文件
- sql - 数据未正确汇总
- r - 如何使用 stringr (str_split) 或 strsplit with r 保留正则表达式
- reactjs - 为什么 HTML5 drawImage 不在画布上绘制图像?
- sql - SQL:表达式不在 GROUP BY 键中
- c# - 在 Xamarin.Forms.Maps Visual Studio 上使用 C# 代码中的变量从 .xaml 文件更改静态地图坐标
- reactjs - 故事书样式不一致
- java - 如何使用子字符串而不是 charAt 检查单词是否为回文?