- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我想制作一张卡片作为聊天正文,因此占据了屏幕的整个高度,因为除了聊天正文之外不会显示任何其他内容,我希望它占据屏幕上的所有空间。在卡片中,我有两列都需要独立滚动。所以我不希望网站可以滚动,而是卡片内的两列。第一列用于实际聊天,第二列用于聊天用户列表。
虽然我让它可以通过像素设置硬编码的最大高度值,但我似乎无法让它与自动全屏高度一起工作。
发生的事情是卡片被呈现为全高,但是尽管有 overflow-y: auto
内容还是溢出了卡片,当设置溢出滚动时,它基本上使滚动条准确内容的高度。
代码:
html, body
{
height: 100vh;
}
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet"/>
<div class="container h-100">
<div class="card h-100">
<div class="card-header">
100% Height card
</div>
<div class="card-body">
<div class="row">
<div class="col-10">
<div style="overflow-y: scroll;" class="mh-100">
Independent scrollable column<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
</div>
</div>
<div class="col-2">
<div stlye="overflow-y: auto" class="mh-100">
Independent scrollable column #2
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
Text<br>
</div>
</div>
</div>
</div>
</div>
至于现在我开始计算 jQuery 中的最大高度,因为它相当简单并且允许我放置我想要的任何内容而不用担心改变高度百分比:
$(document).ready(function()
{
calculateHeight();
$(window).resize(function() { calculateHeight() });
});
function calculateHeight()
{
let wnHeight = $(window).height();
let boxHeight = $("#messagesBox").height();
let cardHeight = $("#messagesCard").outerHeight();
let cardPos = $("#messagesCard").offset();
// calculate the offset to the bottom, this is how much we need to expand (or shrink)
let offset = boxHeight + (wnHeight - (cardHeight + cardPos.top));
if(offset < 480) // this just prevents the card from getting too small
offset = 480;
$("#messagesBox").css('max-height', `${offset}px`);
}
最佳答案
我已经举例说明了如何使用 FLEX 来解决这个问题和 SIZING来自 Bootstrap 4
的实用程序。首先,使用 CSS
,我们将总的view-port height 分为card-header 和card-body (15% 到标题,85% 到正文)。其次,我们使用 w-* 类代替 col-* 进行体宽划分,将 d-flex 类应用于 body 。第三,为了保持 html
标记简单,我们从 JQuery
填充容器。希望对您有所帮助。
$(document).ready(function()
{
// Fill the message and friend containers.
for (var i = 0; i < 30; i++)
{
$("#msgWrap").append("<div class='text-primary'>Message " + i + "</div>");
$("#friendWrap").append("<div class='text-danger'>Friend " + i + "</div>");
}
});
html, body {
height: 100vh;
}
.card-header {
max-height: 15vh;
}
.card-body {
max-height: 85vh;
}
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script>
<div class="container-fluid">
<div class="card">
<div class="card-header d-flex align-items-center text-white bg-dark">
<span class="mx-auto">100% Height card</span>
</div>
<div class="card-body d-flex">
<div id="msgCol" class="d-flex flex-column w-75">
<div id="msgWrap" class="w-100" style="overflow-y:scroll"></div>
<input class="w-100" type="text" placeholder="Write a new message"/>
</div>
<div id="friendCol" class="d-flex flex-column w-25">
<div id="friendWrap" class="w-100" style="overflow-y:scroll"></div>
<div class="w-100 border border-primary text-center text-bold">
FOOTER
</div>
</div>
</div>
</div>
</div>
关于html - Bootstrap 4 全高卡带独立滚动列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52995704/
如果附加了 'not-scroll' 类,我希望我的 body 不滚动,否则它应该正常工作。 我已经搜索这个问题两天了,但找不到任何适合我的解决方案。 我想要的是向 body 添加一个 class,并
我发现似乎是 iOS Safari 中的错误(我正在 iOS 8 上进行测试)。当绝对定位的 iFrame 漂浮在一段可滚动内容上方时,滚动 iFrame 也会滚动下面的内容。以下 HTML (ava
我有以下代码来显示一系列投资组合图片,这些图片以 SVG 格式存储在滚动 div 中: 在 Safari 中滚动使用两根手指或鼠标滚轮当光标位于 SVG 之一上时不起作用。 该页
我想用 javascript 做的是: 一旦你向下滚动页面,将#sidebar-box-fixed 的位置从 position: relative; 更改为定位:固定;。改回position:rela
我对 Elasticsearch 的滚动功能有点困惑。在 elasticsearch 中,每当用户在结果集上滚动时,是否可以每次调用搜索 API?来自文档 "search_type" => "scan
我试图做到这一点,以便当我向上或向下滚动页面时,它会运行不同的相应功能。我发现了一个类似的问题here但我已经尝试了他们的答案并且没有运气。 注意:此页面没有正常显示的滚动条。没有地方可以滚动。 bo
(C语言,GTK库) 在我的表单上,我有一个 GtkDrawingArea 小部件,我在上面使用 Cairo 绘制 GdkPixbufs(从文件加载)。我想要完成的是能够在窗口大小保持固定的情况下使用
最近我一直在尝试创建一个拉到(刷新,加载更多)swiftUI ScrollView !!,灵感来自 https://cocoapods.org/pods/SwiftPullToRefresh 我正在努
我正在开发一个应用程序,其中有两个带有可放置区域的列表和一个带有可拖动项目的侧面菜单。 当我滚动屏幕时,项目的位置困惑。 我试图在谷歌上寻找一些东西,最后得到了这个问题:jQuery draggabl
我在 UIWebView 中加载了一个 HTML 表单,而我的 UIWebView 恰好从 View 的中间开始并扩展。我必须锁定此 webView 不滚动并将其放在 ScrollView 之上以允许
如何在每个元素而不是整个元素上应用淡入淡出(与其高度相比)? HTML: CSS: * { padding: 0; margin: 0; box-sizing: border
我想使用带有垂直轴的 PageView 并使用鼠标滚动在页面之间移动,但是当我使用鼠标滚动时页面不滚动...仅页面单击并向上/向下滑动时滚动。 有什么办法吗? 我想保留属性 pageSnapping:
我制作这个程序是为了好玩,但我被卡住了,因为程序在屏幕外运行。如何在不完全更改代码的情况下实现滚动条。 public static void main(String args[]) throws IO
我想使用带有垂直轴的 PageView 并使用鼠标滚动在页面之间移动,但是当我使用鼠标滚动时页面不滚动...仅页面单击并向上/向下滑动时滚动。 有什么办法吗? 我想保留属性 pageSnapping:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
使用 jquery 技术从 css-tricks.com 获得滚动/跟随侧边栏,如果您不知道我在说什么,这里是代码: $(function() { var $sidebar = $
我是 jQuery Mobile 新手。我需要向我的应用程序添加 Facebook 滑动面板功能。 我经历了 sliding menu panel ,它工作正常,但我在菜单面板中的内容超出了窗口大小,
有没有办法在 js 或 jQuery 或任何其他工具中检测 ctrl + 滚动。我正在尝试执行一些动态布局代码,我需要检测不同分辨率下的屏幕宽度,我通过使用 setTimeout() 的计时器实现了这
我有一部分html代码:
我想控制 RichTextBox 滚动,但在控件中找不到任何方法来执行此操作。 这样做的原因是我希望当鼠标光标位于 RichTextBox 控件上时鼠标滚轮滚动有效(它没有事件焦点:鼠标滚轮事件由表单
我是一名优秀的程序员,十分优秀!