- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有包含动态内容和多行文本的容器。如果文本不适合容器,我想显示省略号 (...)。它也应该垂直居中对齐。
我创建了一个 Codepen http://codepen.io/anon/pen/ewnxG使用此 HTML:
<div class="vertically-centered">vertically centered with</div>
<div class="vertically-centered">vertically centered with hello</div>
<div class="vertically-centered">one line</div>
和这个 CSS:
.vertically-centered {
border: 1px solid red;
height: 6rem;
overflow: hidden;
font-weight: bold;
font-size: 2.5rem;
text-overflow: ellipsis;
width: 300px;
line-height: 1.2;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
}
.vertically-centered:after {
content: "";
height: 100%;
display: inline-block;
vertical-align: middle;
}
在 IE11 和 Firefox 中,省略号“...”不见了,这对我来说没问题。在 Safari 和 Chrome 中它有效。
你看,第一个 div
不起作用,文本被截断了。第二个和第三个 div
有效。所以我的解决方案取决于文本长度。如何在不使用 JavaScript 的情况下解决这个问题?
最佳答案
请检查这个没有额外标记的简单解决方案:
.vertically-centered {
border: 1px solid red;
height: 6rem;
overflow: hidden;
font-weight: bold;
font-size: 2.5rem;
text-overflow: ellipsis;
width: 300px;
line-height: 1.2;
display: flex; /* enables centering for modern non-webkit browsers */
flex-direction: column;
justify-content: space-around; /* centers for modern non-webkit browsers */
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
-webkit-box-pack: center; /* centers in -webkit-box automagically! */
}
<div class="vertically-centered">vertically centered with</div>
<div class="vertically-centered">vertically centered with hello</div>
<div class="vertically-centered">one line</div>
工作原理:您的原始代码已经为基于 WebKit 的浏览器使用了 Flexbox 布局(事实上,它是 Flexbox 的过时 2009 语法,但不幸的是,-webkit-line- clamp
不适用于新的实现)。 Flexbox 有自己的垂直居中机制。要在基于 WebKit 的浏览器中获得所需的行为,您只需删除 :after
伪元素并将以下代码行添加到 .vertically-centered
:
-webkit-box-pack: center;
对于其他现代浏览器,如 Firefox 22+ 和 IE11+,可以通过使用新版本的 Flexbox 实现相同的布局(除了省略号,但你说没关系):
display: flex;
flex-direction: column;
justify-content: space-around;
这必须放在代码中 display: -webkit-box
之上,因此 Webkit 浏览器仍然可以应用 -webkit-line-clamp
。
您还可以通过添加其前缀版本的 Flexbox(2011 过渡语法)使其在 IE10 中工作:
display: -ms-flexbox;
-ms-flex-direction: column;
-ms-flex-pack: center;
支持IE10的笔在这里:http://codepen.io/anon/pen/otHdm
:after
垂直居中方法在第一个“单元格”中不起作用,原因如下:对于 ilnine-level CSS 框(如通常的文本、内联 block 、图像等) vertical-align
调整构成line box 的所有此类框的基线(参见CSS2.1 spec)。计算线框的高度,使行中的所有行内级框都适合它,所以线框的高度不能小于其中最高的行内级框的高度。所以你的 :after
内联 block ,它获得容器高度的 100%,成为你 block 的 last 行中最高的元素,并且由于 vertical- align: middle
最后一行中 text 的基线移动到文本的垂直中间与这个高内联 block 的中间相交。当只有一个石灰(这是这种居中的典型用例)并且最后一行被 overflow
隐藏时,这是可以的,但当它可见时则不行。
关于html - 盒子中的多行有省略号和垂直对齐中间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25719238/
我正在制作一款打算在 future 进行本地化的软件。我想知道省略号(...指示一个 Action 打开一个新窗口/对话框)通常是如何本地化的。 所有语言都这样使用省略号吗?我可以在自己的代码中安全地
我正在尝试实现以下布局(请参阅下面的屏幕截图)。 如果 SPAN 和 B 都符合条件 - 它们只是一个接一个。 如果没有 - SPAN 有一个省略号,但 B 完全显示(它永远不会大于整个 block
我理解点-点-点的一般含义。当我想创建自己的参数数量未知的函数时,我了解如何使用它。 我不明白它是如何工作的,例如函数 variable.names()。当我执行 ?variable.names 时,
在 jqGrid 中,如果文本不适合并被截断,是否有一种本地方法可以在列末尾显示“...”? 我看到有一个 ui-ellipsis 类,但我很困惑,如果文本被截断,它是否会自动添加,以及一旦调整列大小
我有几个 JS 语法问题。 首先,有什么好的资源可以帮助您快速掌握与以下类似的 JS 语法? 代码中,Q1和Q2是标签吗?另外,...的用途是什么? const Q1: Query = { 'is
我正在阅读一些旧代码,这些代码似乎旨在删除目录中的一系列句点 (......)。它利用 java 正则表达式来完成此操作。这是使用的代码。 input = input.replaceAll( ".*.
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
我正在尝试让省略号像这样工作:http://jsfiddle.net/583mK/1/ 有趣的是,它在 jsFiddle 上运行良好。奇怪的是,它提供了完全相同的 HTML/CSS,但它在我的应用程序
我有多个不同长度的标题,我希望它们总是占用 1 行并在它们不适合时留下悬挂点/省略号 (...)。我不能只更改 div 中的文本,因为其中的 h2 每天都会自动更改。 这是我的代码:http://js
有十亿个教程,但不幸的是,没有一个对我有用。我需要一些艺术家姓名在标题中,居中,但带有 css 省略号,所以很长的名字会得到“...”并将被截断。 您可以在此处查看设计:http://www.cphr
这个问题在这里已经有了答案: text overflow ellipsis: avoid word break (3 个答案) 关闭 3 年前。 我正在显示带有省略号的文本。在我当前的 CSS 中,
我要画圈 ,就像这张图片: 我试过这段代码。 .discussion:after { content: '\2807'; font-size: 1em; background: #2d34
我在玩python。我在 IDLE 中使用了以下代码: p = [1, 2] p[1:1] = [p] print p 输出是: [1, [...], 2] 这是什么[…]?有趣的是,我现在可以将其
我对省略号很陌生,但即使我将变量分配为 false,以下内容也会返回 true。 PS:注意 if 条件。 import system.obj.* from elipsis.system; iff(e
我正在使用 alabama 包中的 constrOptim.nl 进行非线性优化。但是,我的问题更多地与传递参数(和点-点-点(省略号/“...”)和可能的 do.call)有关 - 所以我首先给出一
例如,我知道如何使用 numpy 对数组进行切片 v[1, :, :] 现在我想要一个函数将切片 (1,1,None) 作为输入并返回 v[1,:,:] 问题是我不知道如何表示省略号 最佳答案 您可以
我有一个宽度设置为 100%。里面是一个带有文本字符串的 div,如果文本宽度溢出,我想在其中添加省略号。 在 javascript 中,我设置了 的宽度到 的宽度这在加载(或刷新)时工作正常,但
有什么方法可以使用 Angular js 对字符串进行子串并在末尾添加省略号,同时忽略 anchor 标记(如果它位于子字符串内部)? 例如,我的文字是: Lorem Ipsum has been t
我不知道为什么这个简单的CSS无法正常工作... .app a { height: 18px; width: 140px; padding: 0; overflow: hidden;
这个问题在这里已经有了答案: text-overflow is not working when using display:flex (5 个答案) 关闭 3 年前。
我是一名优秀的程序员,十分优秀!