- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个模态对话框,当模态内容太大而无法包含时,它会出现一个垂直滚动条。
我的问题是:当我想要“弹出”模式的控件(实际上是 Twitter Typeahead https://twitter.github.io/typeahead.js/)出现时,它会导致模式上的滚动条扩展。
可能最好通过示例来解释:
期望的行为
https://jsfiddle.net/0eara5xc/14/显示我想要的行为(在输入框中输入字母“a”),但是当常规内容太大(我需要)时,模式不会滚动。
不良行为
一旦我使模态可滚动,弹出窗口就会导致滚动条增加。
.modal-body {
max-height: 40vh;
overflow: hidden;
overflow-y: auto;
}
最佳答案
这里的问题是你想要有两件事是矛盾的。我将用几个例子来解释,直到我达到我的解决方案的想法。
如果我们采用流入元素(容器和内部元素),我们有两种情况:
(1) 内部元素的高度小于或等于 到容器的高度。在这种情况下,所有溢出( auto
、 scroll
和 hidden
)都是相同的。
(2) 内部元素的高度更大 比容器的高度,在这种情况下,我们:
.el {
border:5px solid green;
height:100px;
}
.el > div {
height:200px;
width:100%;
background:red;
}
<div class="el">
<div>
</div>
</div>
overflow:hidden
隐藏一些内部元素所以我们看不到 溢出的部分。 .el {
border:5px solid green;
height:100px;
overflow:hidden;
}
.el > div {
height:200px;
width:100%;
background:red;
}
<div class="el">
<div>
</div>
</div>
overflow:scroll
隐藏一些内部元素,我们只能看到溢出部分滚动 . .el {
border:5px solid green;
height:100px;
overflow:scroll;
}
.el > div {
height:200px;
width:100%;
background:red;
}
<div class="el">
<div>
</div>
</div>
absolute:position
时几乎在所有情况下(除非我们为容器定义大高度)我们都会处于情况(2),因为绝对定位元素不在流中并且是
容器高度计算中未考虑 所以从逻辑上讲,内部元素的高度会更大,并且上面的相同逻辑将适用:
.el {
border:5px solid green;
position:relative;
}
.el > div {
height:100px;
background:red;
}
.el > div:last-child {
position:absolute;
background:blue;
right:0;
left:0;
}
<div class="el">
<div>
we see the element
</div>
<div>
</div>
</div>
<div class="el" style="overflow:hidden;margin-top:100px;">
<div>
we don't see the element
</div>
<div>
</div>
</div>
<div class="el" style="overflow:scroll;">
<div>
we see the element element on scroll
</div>
<div>
</div>
</div>
overflow
也适用相同的逻辑。属性设置为绝对定位元素的另一个元素祖先。如您所见
here :
In most cases, overflow can be computed for any box from the bounds and properties of that box itself, plus the overflow of each of its children.
overflow:scroll
当任何子元素的高度增加或溢出时,滚动总是会增加,并且没有办法在外面有任何溢出的元素,因为这是默认行为,您可以通过设置
overflow:scroll
来更改它.
overflow:scroll
的元素之间和绝对定位元素你不应该找到任何定位元素。正如您在这个复杂的声明中所读到的
here :
... a box may overflow, meaning its content lies partly or entirely outside of the box, e.g.:
[...]
A descendant box is positioned absolutely, partly outside the box. Such boxes are not always clipped by the overflow property on their ancestors; specifically, they are not clipped by the overflow of any ancestor between themselves and their containing block
position:fixed
.像这样,它将相对于浏览器窗口,我们可以在滚动之外看到它,但是很难使用 CSS 调整它的位置。这种情况下我们可以考虑一些JS来动态调整元素的位置:
$('.typeahead').on('keypress change',function(e){
var y = $(this).offset().top + $(this).height();
var x = $(this).offset().left;
$('.tt-menu').css('top',y);
$('.tt-menu').css('left',x);
})
$(function () {
$('.typeahead').on('keypress change',function(e){
var y = $(this).offset().top + $(this).height()+5;
var x = $(this).offset().left;
$('.tt-menu').css('top',y);
$('.tt-menu').css('left',x);
})
$('#btnPopup').on('click', function(){
$('#divPopup').toggle();
});
var substringMatcher = function(strs) {
return function findMatches(q, cb) {
var matches, substringRegex;
// an array that will be populated with substring matches
matches = [];
// regex used to determine if a string contains the substring `q`
substrRegex = new RegExp(q, 'i');
// iterate through the pool of strings and for any string that
// contains the substring `q`, add it to the `matches` array
$.each(strs, function(i, str) {
if (substrRegex.test(str)) {
matches.push(str);
}
});
cb(matches);
};
};
var states = ['Alabama', 'Alaska', 'Arizona', 'Arkansas', 'California',
'Colorado', 'Connecticut', 'Delaware', 'Florida', 'Georgia', 'Hawaii',
'Idaho', 'Illinois', 'Indiana', 'Iowa', 'Kansas', 'Kentucky', 'Louisiana',
'Maine', 'Maryland', 'Massachusetts', 'Michigan', 'Minnesota',
'Mississippi', 'Missouri', 'Montana', 'Nebraska', 'Nevada', 'New Hampshire',
'New Jersey', 'New Mexico', 'New York', 'North Carolina', 'North Dakota',
'Ohio', 'Oklahoma', 'Oregon', 'Pennsylvania', 'Rhode Island',
'South Carolina', 'South Dakota', 'Tennessee', 'Texas', 'Utah', 'Vermont',
'Virginia', 'Washington', 'West Virginia', 'Wisconsin', 'Wyoming'
];
$('.typeahead').typeahead({
hint: true,
highlight: true,
minLength: 1
},
{
name: 'states',
source: substringMatcher(states)
});
});
.modal-body {
max-height: 40vh;
overflow: hidden;
overflow-y: auto;
}
.modal-header, .modal-footer {
background-color: black;
color: white;
}
#divSpacer {
height: 40vh;
background-color: rgb(220, 220, 220);
}
.tt-menu {
background-color: red;
position:fixed!important;
}
<script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.js"></script>
<link rel="stylesheet" type="text/css" href="/css/result-light.css">
<link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css">
<script type="text/javascript" src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"></script>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/typeahead.js/0.11.1/typeahead.bundle.min.js"></script>
<div>
<div class="modal-lg">
<div class="modal-header">
My modal title
</div>
<div class="modal-body">
<div id="divSpacer">
Lots of space taken up here...
</div>
<input class="typeahead" type="text" placeholder="States of USA">
</div>
<div class="modal-footer">
</div>
</div>
</div>
关于html - CSS:将元素定位在区域之外而不更改滚动条,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48859408/
我有一个名为 main.css 的 css 文件和另一个名为 style.css 的文件。我怎样才能在 main.css 中做到这一点? .someClass { //apply rules to
在更新我的 css 之前,我在 Login.css 中有以下内容: body { background-image: url('./pictures/fond.png'); bac
我的 share point 2013 核心 css 和我的 css 之间存在 css 冲突。所以我想把我所有的类都放在 div #s4-workspace 下但是我搜索了一种方法来将所有类分组到这个
我知道您可以覆盖 jsp 页面从 jsp 包含 CSS 文件(即全局 CSS 文件)继承的 CSS 属性。 但是,如果元素中的某个属性弄乱了特定页面,而我不想只使用内联 CSS 在该页面中使用它怎么办
我刚刚发现了 initial-scale 元属性。 以前,我一直在使用 default.css 来定义我所有的样式和大小(用于字体和元素),以便它们在桌面计算机的屏幕上显示得很好。然后,如果您使用的是
我正在尝试使用 LESS CSS 来编写我的 CSS。我已经按顺序导入了 style.less 和 less.js 文件。 现在我想提取 LESS 生成的 CSS。有什么办法可以做到吗?我不想使用脚本
我想知道是否有任何一种软件可以读取大量内联样式中的 HTML 文档并将所有这些样式转换为外部 css 文件。如果只有一页,我可以手动完成。但是有100页。有人有想法吗? 最佳答案 就像有人说的那样,“
当我想从 Styled Components 迁移到 CSS Modules 时,出现了以下问题。 假设我有以下样式组件,它接受动态参数 offset和一个动态 CSS 字符串 theme : con
有没有办法将 CSS 类定义为与另一个类相等?例如,如果我有一个类: .myClass{ background-color: blue; } 有没有一种方法可以将第二个类定义为与 myClas
我正在尝试制作一组按钮,这些按钮贴在页面底部并且由固定的空间隔开。我正在使用 angularJS 的 ng-repeat 指令通过 ajax 请求获取数据,然后我用它来显示按钮。 我的问题在于让按
浏览器是否在加载 CSS 文件时解析 CSS?还是在整个 CSS 文件被浏览器下载后才进行解析?不同浏览器的做法有区别吗?我在哪里可以找到这种底层信息? 这个问题不是 Load and executi
这个问题在这里已经有了答案: Can a CSS class inherit one or more other classes? (29 个答案) 关闭 3 年前。 标题有点乱,我给大家看一下。假
我遇到了最奇怪的问题...... 在最简单的形式中,我有一个包含以下内容的 index.html 文件: (在尝试确定根本原因的过程中,我已经大大减少了它) 当我查看页面的源代码时,我得到以下信息:
我正在使用 Mindscape Workbench 来最小化我的 scss 文件。我的页面设置为使用 *.min.css 文件。在随机时间,min 文件不会与系统的其余部分一起发布。 我有很多 css
请告诉我 CSS 框架和 CSS 网格之间的区别。 最佳答案 CSS 框架也可以是 CSS 网格框架。 CSS 网格框架用于构建 CSS 布局。有一些框架除了构建布局还有其他用途,例如 Hartija
我有无法从页面中删除或更改的 original.css 文件。原始.css table { border-collapse: collapse; border-spacing: 0;
我以前使用 bootstrap css import 很好。 但是我正在尝试使用 CSS 模块,所以我添加了几行。 { test: /\.css$/, use:
有没有办法在 css 选择器中创建一个 css 组。 例如: .SectionHeader { include: .foo; include: .bar; include: .
今天我学习了 CSS 中的两个概念,一个是 CSS 定位(静态、相对、绝对、固定),另一个是 CSS Margin,它定义了元素之间的空间。 假设我想移动一个元素,这是最好的方法吗?因为这两个概念似乎
var paths = { css: './public/apps/user/**/*.css' } var dest = { css: './public/apps/user/css/' } /
我是一名优秀的程序员,十分优秀!