- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想显示一个模式对话框,但我正在努力将 flex 布局和具有固定位置的对话框组合起来。页眉和页脚需要固定高度;内容部分有滚动条溢出。我在这里选择 flex 布局的原因是标题可以隐藏或高度变化,在这种情况下我希望内容占据所有可用的高度。
但是,如果我有一个带有位置的模态对话框:相对(md-modal),一切都会完美。
一旦我更改为位置:固定在 md-modal 上,一切都会中断。我没有看到造成这种情况的根本原因。我在这里遇到了规范问题吗?
我将情况封装在 600/400 包装中,只是为了便于查看。
<html>
<head>
<style type="text/css">
html,
body {
height: 100%;
margin: 0
}
.md-modal {
position: fixed;
top: 50%;
left: 50%;
width: auto;
height: auto;
border:1px solid green;
z-index: 2000;
visibility: hidden;
-webkit-backface-visibility: hidden;
-moz-backface-visibility: hidden;
backface-visibility: hidden;
-webkit-transform: translateX(-50%) translateY(-50%);
-moz-transform: translateX(-50%) translateY(-50%);
-ms-transform: translateX(-50%) translateY(-50%);
transform: translateX(-50%) translateY(-50%);
}
.md-show {
visibility: visible;
}
.md-content {
position: relative;
color: #000;
background: #fff;
border-radius: 3px;
margin: 0 auto;
}
.md-effect-1 .md-content {
-webkit-transform: scale(0.7);
-moz-transform: scale(0.7);
-ms-transform: scale(0.7);
transform: scale(0.7);
opacity: 0.2;
-webkit-transition: all 0.3s;
-moz-transition: all 0.3s;
transition: all 0.3s;
}
.md-show.md-effect-1 .md-content {
-webkit-transform: scale(1);
-moz-transform: scale(1);
-ms-transform: scale(1);
transform: scale(1);
opacity: 1;
}
.box {
display: flex;
flex-flow: column;
height: 100%;
}
.box .row {
border: 1px dotted grey;
}
.box .row.header {
flex: 0 1 auto;
}
.box .row.content {
flex: 1 1 auto;
overflow-y:auto;
}
.box .row.footer {
flex: 0 1 40px;
}
</style>
</head>
<body>
<a href="javascript:document.getElementById('dialog').classList.add('md-show')">test</a>
<div style="width:600px;height:400px">
<div class="md-modal md-effect-1 center" id="dialog">
<div class="md-content">
<div class="box">
<div class="row header">
<p><b>header</b>
<br />
<br />(sized to content)</p>
</div>
<div class="row content">
<p>
<b>content</b><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p>
<p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p><p>line</p>
(fills remaining space)
</p>
</div>
<div class="row footer">
<p><b>footer</b> (fixed height)</p>
</div>
</div>
</div>
</div>
</div>
</body>
</html>
最佳答案
position:fixed
,就像 position:absolute
将元素从文档流中取出一样。就其父级而言,它几乎就像不存在一样。
这意味着它与文档流中的元素在相同的空间上呈现。
absolute
和 fixed
之间的区别在于,绝对定位的元素是相对于其最接近的定位父元素进行定位和调整大小的,而 fixed
的元素相对于最接近的视口(viewport)进行定位和调整大小。
这意味着您想要:在模态容器上使用 position:fixed
,该容器应该具有视口(viewport)的大小。该容器是不可见的(透明的)并且包含实际的模态。您可以使用选择的居中技术,但我建议使用
.modal-container {
display: flex;
align-items: center;
justify-content: center;
}
我强烈建议不要使用绝对居中方法,例如 transform:translate(-50%, -50%)
,因为当模态结果高于视口(viewport)时,它们会严重失败(您失去访问顶部的能力)。
也就是说,这是一个非常基本的模态示例:
document.querySelector('#showModal').addEventListener('click', function(){
document.querySelector('.modal-container').classList.add('open');
})
document.querySelector('#hideModal').addEventListener('click', function(e){
e.preventDefault();
document.querySelector('.modal-container').classList.remove('open');
})
.modal-container {
position: fixed;
width: 100vw;
height: 100vh;
display: none;
justify-content: center;
align-items: center;
}
.modal-background {
background-color: rgba(0,0,0,.42);
position: absolute;
height: 100%;
width: 100%;
z-index: -1;
}
.modal {
position: relative;
background-color: white;
display: flex;
width: 900px;
min-height: 80vh;
flex-direction: column;
}
#hideModal {
position: absolute;
top: 1em;
right: 1em;
}
.open.modal-container {
display: flex;
}
.modal > * {
flex-grow: 0;
padding: 0 1rem;
}
.modal-body {
flex-grow: 1;
}
.modal-head, .modal-footer {
background-color: #eee;
}
.modal-footer {
padding: 1rem;
}
@media (max-width: 1200px) {
.modal {
width: 600px;
}
}
@media (max-width: 767px) {
.modal {
width: 90vw;
}
}
<div class="modal-container">
<div class="modal-background"></div>
<div class="modal">
<a id="hideModal" href>Hide modal</a>
<div class="modal-head">
<h1>Modal title</h1>
</div>
<div class="modal-body">
This is the modal body
</div>
<div class="modal-footer">
This is the modal footer
</div>
</div>
</div>
<button id="showModal">Show modal</button>
大多数人选择使用已经完善且经过充分测试的模态插件。此外,大多数流行的框架都带有自己已定义且可供使用的模式。
当然,构建您自己的动画可以完全自由地控制打开和关闭动画及其任何可重用功能。
以下是标记的快速修复:
html,
body {
height: 100%;
margin: 0
}
.md-modal {
position: fixed;
min-height: 100vh;
width: 100vw;
top: 0;
left: 0;
border: 1px solid green;
z-index: 0;
visibility: hidden;
backface-visibility: hidden;
display: flex;
align-items: flex-start;
justify-content: center;
background-color: rgba(0,0,0,.35);
height: 100%;
overflow: auto;
}
.md-show {
visibility: visible;
}
.md-content {
color: #000;
background: #fff;
border-radius: 3px;
margin: 5vw auto;
width: 90vw;
min-height: calc(100vh - 10vw);
display: flex;
}
.md-content>* {
flex-grow: 0;
flex-shrink: 0;
}
.md-effect-1 .md-content {
transform: scale(0.7);
opacity: 0.2;
transition: all 0.3s;
}
.md-show.md-effect-1 .md-content {
transform: scale(1);
opacity: 1;
}
.box {
display: flex;
flex-flow: column;
flex-grow: 1;
}
.box .row {
border: 1px dotted grey;
}
.box .row.header {
flex: 0 0 auto;
}
.box .row.content {
flex: 0 1 auto;
overflow-y: auto;
}
.box .row.footer {
flex: 0 1 40px;
}
.md-content .box .content {
flex-grow: 1;
}
<a href="javascript:document.getElementById('dialog').classList.add('md-show')">test</a>
<div class="md-modal md-effect-1 center" id="dialog">
<div class="md-content">
<div class="box">
<div class="row header">
<p><b>header</b>
<br />
<br />(sized to content)</p>
</div>
<div class="row content">
<p>
<b>content</b>
<p>line</p>
<p>line</p>
<p>line</p>
<p>line</p>
<p>line</p>
<p>line</p>
(fills remaining space)
</div>
<div class="row footer">
<p><b>footer</b> (fixed height)</p>
</div>
</div>
</div>
</div>
关于html - 将 flex 与位置 :fixed 结合起来,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52937784/
更新 对于那些不喜欢内联 CSS 并想要类的人,这里有另一个带有类和样式表的 jsFiddle。 更新结束 我想做一个产品页面。它将包含三列。第一个是图片,第二个是一些规范,第三个是“入篮”。所有列的
我创建了一个简单的测试应用程序 使用以下代码 var i : int; for (i=0; i *
我做了一个小demo http://html5.by/blogdemo/flexbox/flex-grow-shrink-basis-stackoverflow.html flex 容器中有2个 fl
我读过好几遍,要让 flex-grow 按预期工作,您通常需要设置 flex-grow:1(或 flex: 1) 在元素的父级、其父级等上,一直向上。 在学习 flexbox 时,这给我的印象是它具有
我开始学习 FLEX。我只有 flex sdk。所以我只能使用它开始学习吗?如果是这样,请建议我要通过的链接.. 但是,使用编辑器将最大限度地减少我们的工作,并自行创建代码。所以作为一个新的学习者,理
有没有办法使用 flex-direction: column 在 flex 容器中放置 flex 项有相同的高度,只使用 CSS? JSFiddle:https://jsf
我有一个 flex .swf 和一个单独的 AIR 项目,我试图通过套接字相互通信。 这两个程序连接正常,.swf 能够毫无问题地将数据发送到 AIR 应用程序。但是,我发现当 AIR 应用程序将数据
在这种情况下,我希望将 2.5 放置在 2 下方 - 但 flexbox 容器强制将其放置在同一行,而不是将其放置在 div 下方那已经是那个特定的顺序了。 我如何使用 flexbox - 将包含 2
假设您有一个带有显示 flex、flex-direction 列的 div,在本例中高度为 600。 它有三个子项,每个子项的属性 flex 等于 1。前两个子项呈现一些简单文本,第三个子项呈现 h1
男孩,这个头衔是满口的。让我解释一下我的困惑: 我有一个 flex 容器和 2 个 flex 元素。 /* CSS */ .container {
这个问题在这里已经有了答案: CSS3 Flexbox: display: box vs. flexbox vs. flex (3 个答案) 关闭 1 年前。 今天我们中的许多人都知道 displa
其用例是带有单选按钮的响应式表单。当在大 PC 屏幕上时,所有单选按钮通常都在屏幕上的一行中(就像带有 flex-direction: row 的非包装 flex 容器中的 flex 元素)。在电话上
在可访问的 flex 应用程序中,用户可以使用 TAB 键在控件中导航。 在用户激活特定链接后,flex 应用程序会在 html 页面顶部弹出,并使用 swfobject.embedSWF 加载。 它
我将我的 Flex 3 项目导入 Flex 4 并删除了 Flex 4 问题窗口中列出的所有错误和警告。 启动我的应用程序时,我在 Flex 4 中遇到以下错误。 这可能是什么原因? Error: C
我有如下标记: alot of text 我不能让黄色占据红色的 100% 高度,即使红色溢出,它也只占据窗口的 100%。如果我将红色的 display
我在 Eclispe 3.4 中安装了 flex builder 3 插件。现在许可证过期了。所以我需要在其中添加另一个许可证。但我无法更改许可证 key ,因为该选项已禁用。 因此,请任何人知道如何
这个问题在这里已经有了答案: Make flex items have equal width in a row (3 个答案) How to make Flexbox items the same
我正在尝试理解以下行。 flex :0 1 50% 现在,如果最后一个值,flex basis 是像素,上面会说该元素不允许增长,但允许缩小并且最大为 50 像素。 但是用百分比代替,有什么关系。它将
我一直致力于 flex 布局,遇到了针对 Firefox 和 IE11 的问题。 我创建了一个 codepen显示问题。 截图 Chrome(左)、Firefox(右) 描述 预期的行为是header
我正在尝试在 flex (flash builder 4) 中创建一个简单的表单。我在里面放了一个表单容器和 FormItems。例如,表单项是标准的“客户”字段,例如名字、姓氏、地址、城市、州、 z
我是一名优秀的程序员,十分优秀!