- 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/
SO亲爱的 friend 们: 2014 年 3 月 18 日。我正在处理一种情况,在使用 ng-repeat 时,数组内的元素(我从 Json 字符串中获取)更改了原始顺序。 需要明确的是,数组中的
有很多问题询问如何在 JavaScript 单击处理程序中更改 div 的类,例如,此处:Change Div style onclick .我理解得很好(只需更改 .className),并且它有效
我从access导入了一个数据库到mysql,但其中一个表的列名“股数”带有空格,但我尝试更改、替换甚至删除列名,但失败了。任何人都可以帮助解决这一问题 String UpdateQuary = "U
我正在做一个随机的学校元素。 目前,我有一个包含两个 CSS 的页面。一种用于正常 View ,一种用于残障人士 View 。 此页面还包括两个按钮,它们将更改使用的样式表。 function c
我需要使用 javascript 更改 HTML 元素中的文本,但我不知道该怎么做。 ¿有什么帮助吗? 我把它定义成这样: Text I want to change. 我正在尝试这样做: docum
我在它自己的文件 nav_bar.shtml 中有一个主导航栏,每个其他页面都包含该导航栏。这个菜单栏是一个 jQuery 菜单栏(ApyCom 是销售这些导航栏的公司的名称)。导航栏上的元素如何确定
我正在摆弄我的代码,并开始想知道这个变化是否来自: if(array[index] == 0) 对此: if(!array[index] != 0) 可能会影响任何代码,或者它只是做同样的事情而我不需
我一直在想办法调整控制台窗口的大小。这是我正在使用的函数的代码: #include #include #define WIDTH 70 #define HEIGHT 35 HANDLE wHnd;
我有很多情况会导致相同的消息框警报。 有没有比做几个 if 语句更简单/更好的解决方案? PRODUCTS BOX1 BOX2 BOX3
我有一个包含这些元素的 XELEMENT B Bob Petier 19310227 1 我想像这样转换前缀。 B Bob Pet
我使用 MySQL 5.6 遇到了这种情况: 此查询有效并返回预期结果: select * from some_table where a = 'b' and metadata->>"$.countr
我想知道是否有人知道可以检测 R 中日期列格式的任何中断的包或函数,即检测日期向量格式更改的位置,例如: 11/2/90 12/2/90 . . . 15/Feb/1990 16/Feb/1990 .
我希望能够在小部件显示后更改 GtkButton 的标签 char *ButtonStance == "Connect"; GtkWidget *EntryButton = gtk_button_ne
我正在使用 Altera DE2 FPGA 开发板并尝试使用 SD 卡端口和音频线路输出。我正在使用 VHDL 和 C 进行编程,但由于缺乏经验/知识,我在 C 部分遇到了困难。 目前,我可以从 SD
注意到这个链接后: http://www.newscientist.com/blogs/nstv/2010/12/best-videos-of-2010-progress-bar-illusion.h
我想知道在某些情况下,即使剧本任务已成功执行并且 ok=2,ansible 也会显示“changed=0”。使用 Rest API 和 uri 模块时会发生这种情况。我试图找到解释但没有成功。谁能告诉
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicate: add buttons to push notification alert 是否可以在远程通知显示的警报框中指定有
当您的 TabBarController 中有超过 5 个 View Controller 时,系统会自动为您设置一个“更多” View 。是否可以更改此 View 中导航栏的颜色以匹配我正在使用的颜
如何更改.AndroidStudioBeta文件夹的位置,默认情况下,该文件夹位于Windows中的\ .. \ User \ .AndroidStudioBeta,而不会破坏任何内容? /编辑: 找
我目前正在尝试将更具功能性的编程风格应用于涉及低级(基于 LWJGL)GUI 开发的项目。显然,在这种情况下,需要携带很多状态,这在当前版本中是可变的。我的目标是最终拥有一个完全不可变的状态,以避免状
我是一名优秀的程序员,十分优秀!