We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
这题就厉害了我的哥。
题目就是如上要求,使用纯 CSS,完成单行文本居中显示文字,多行居左显示,最多两行超过用省略号结尾,效果如下:
不愿看长篇大论的可以先看看效果:-webkit- 内核下 Demo 戳我
接下来就一步一步来实现这个效果。
居中需要用到 text-align:center,居左是默认值也就是text-align:left。如合让两者结合起来达到单行居中,多行居左呢?这就需要多一个标签,假设一开始我们定义如下:
text-align:center
text-align:left
<h2>单行居中,多行居左</h2>
现在,我们在 h2 中间,嵌套多一层标签 p:
h2
p
<h2><p>单行居中,多行居左</p></h2>
我们让内层 p 居左 text-align:left,外层 h2 居中 text-align:center,并且将 p 设置为 display:inline-block ,利用 inline-block 元素可以被父级 text-align:center 居中的特性,这样就可以实现单行居中,多行居左,CSS 如下:
display:inline-block
inline-block
p { display: inline-block; text-align: left; } h2{ text-align: center; }
得到的效果如下:
完成了第一步,接下来要实现的是超出两行显示省略符号。
多行省略是有专门的新 CSS 属性可以实现的,但是有些兼容性不大好。主要用到如下几个:
上述 3 条样式配合 overflow : hidden 和 text-overflow: ellipsis 即可实现 webkit 内核下的多行省略。好,我们将上述说的一共 5 条样式添加给 p 元素
overflow : hidden
text-overflow: ellipsis
webkit
p { display: inline-block; text-align: left; overflow : hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; } h2{ text-align: center; }
看看效果如下:
(在 -webkit- 内核浏览器下)发现,虽然超出两行的是被省略了,但是第一行也变回了居左,而没有居中。
看回上面的 CSS 中的 p 元素,原因在于我们第一个设置的 display: inline-block ,被接下来设置的 display: -webkit-box 给覆盖掉了,所以不再是 inline-block 特性的内部 p 元素占据了一整行,也就自然而然的不再居中,而变成了正常的居左展示。
display: inline-block
display: -webkit-box
记得上面我们解决单行居中,多行居左时的方法吗?上面我们添加多了一层标签解决了问题,这里我们再添加多一层标签,如下:
<h2><p><em>单行居中,多行居左<em></p></h2>
这里,我们再添加一层 em 标签,接下来,
em
text-align: center
嘿!通过再设置多一层标签,解决 display 的问题,完美解决问题,再看看效果:
-webkit- 内核下 Demo 戳我
是的,还有第二种方法......
上面我们为了让第一行居中,使用了三层嵌套标签。
这次我们换一种思路,只使用两层标签,但是我们加多一行。结构如下:
<div class="container"> <h2> <p>我是单行标题居中</p> <p class="pesudo">我是单行标题居中</p> </h2> </div>
这里,新添加了一行 class 为 pesudo 的 p 标签,标签内容与文本内容一致,但是我们限定死 class="pesudo" 的 p 标签高度 height 与上面的 p 的行高 line-height一致,并设置 overflow:hidden ,那么这个 p 标签最多只能能展示出一行文本,接下来使用绝对定位,定位到 h2 的顶部,再设置 text-align:center 以及背景色与 h2 背景色一致。
pesudo
class="pesudo"
line-height
overflow:hidden
这样最多显示单行且样式为居中的 class="pesudo" p 标签就重叠到了原本的 p 标签之上。表现为单行居中,多行时第一行则铺满,解决了我们的问题。多行省略与方法一相同。CSS 如下:
h2{ position:relative; line-height:30px; } p{ overflow : hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; } .pesudo{ position:absolute; width:100%; height:30px; overflow:hidden; top:0; background:#ddd; text-align:center; }
最后,新开通的公众号求关注,形式希望是更短的篇幅,质量更高一些的技巧类文章,包括但不局限于 CSS:
The text was updated successfully, but these errors were encountered:
非webkit的咋办呢?
Sorry, something went wrong.
比较实用的多行超出隐藏,我觉得用max-height+line-height去实现会好点 通过::after去增加...
第二种方法如果第一行文字的宽度总和与元素的宽度不相等 会导致第一行首字和 第(1+n)行 的首字不对齐
#test-page { width: 10em; display: flex; justify-content: center; .c-text{ word-break: break-all; text-align: left; @include t-overflow(2); } }
也许还有其它不需要额外dom嵌套的解决办法😆
No branches or pull requests
5、单行居中显示文字,多行居左显示,最多两行超过用省略号结尾
这题就厉害了我的哥。
题目就是如上要求,使用纯 CSS,完成单行文本居中显示文字,多行居左显示,最多两行超过用省略号结尾,效果如下:
不愿看长篇大论的可以先看看效果:-webkit- 内核下 Demo 戳我
接下来就一步一步来实现这个效果。
首先是单行居中,多行居左
居中需要用到
text-align:center
,居左是默认值也就是text-align:left
。如合让两者结合起来达到单行居中,多行居左呢?这就需要多一个标签,假设一开始我们定义如下:现在,我们在
h2
中间,嵌套多一层标签p
:我们让内层
p
居左text-align:left
,外层h2
居中text-align:center
,并且将p
设置为display:inline-block
,利用inline-block
元素可以被父级text-align:center
居中的特性,这样就可以实现单行居中,多行居左,CSS 如下:得到的效果如下:
超出两行省略
完成了第一步,接下来要实现的是超出两行显示省略符号。
多行省略是有专门的新 CSS 属性可以实现的,但是有些兼容性不大好。主要用到如下几个:
上述 3 条样式配合
overflow : hidden
和text-overflow: ellipsis
即可实现webkit
内核下的多行省略。好,我们将上述说的一共 5 条样式添加给p
元素看看效果如下:
(在 -webkit- 内核浏览器下)发现,虽然超出两行的是被省略了,但是第一行也变回了居左,而没有居中。
看回上面的 CSS 中的
p
元素,原因在于我们第一个设置的display: inline-block
,被接下来设置的display: -webkit-box
给覆盖掉了,所以不再是inline-block
特性的内部p
元素占据了一整行,也就自然而然的不再居中,而变成了正常的居左展示。记得上面我们解决单行居中,多行居左时的方法吗?上面我们添加多了一层标签解决了问题,这里我们再添加多一层标签,如下:
这里,我们再添加一层
em
标签,接下来,em
为display: -webkit-box
p
为inline-block
h2
为text-align: center
嘿!通过再设置多一层标签,解决 display 的问题,完美解决问题,再看看效果:
-webkit- 内核下 Demo 戳我
法二: 绝对定位障眼法
是的,还有第二种方法......
上面我们为了让第一行居中,使用了三层嵌套标签。
这次我们换一种思路,只使用两层标签,但是我们加多一行。结构如下:
这里,新添加了一行 class 为
pesudo
的p
标签,标签内容与文本内容一致,但是我们限定死class="pesudo"
的p
标签高度 height 与上面的p
的行高line-height
一致,并设置overflow:hidden
,那么这个p
标签最多只能能展示出一行文本,接下来使用绝对定位,定位到h2
的顶部,再设置text-align:center
以及背景色与h2
背景色一致。这样最多显示单行且样式为居中的
class="pesudo"
p 标签就重叠到了原本的p
标签之上。表现为单行居中,多行时第一行则铺满,解决了我们的问题。多行省略与方法一相同。CSS 如下:-webkit- 内核下 Demo 戳我
最后,新开通的公众号求关注,形式希望是更短的篇幅,质量更高一些的技巧类文章,包括但不局限于 CSS:
The text was updated successfully, but these errors were encountered: