CSS定制文本省略的方法

这次给大家带来CSS定制文本省略的方法,CSS定制文本省略的注意事项有哪些,下面就是实战案例,一起来看一下。

WeTest导读

拿到设计MM的设计稿,Oh NO,点点点后面又双叒叕加内容了,弹丸之地,劳心费神啊!!可怜我们UI开发GG每次苦口婆心说,微臣不是不做,是办不到啊!很是愧疚。而现在,自从用了定制多行省略,腰不酸了,手也不疼了,接起需求来,毫不费劲!
 

一、什么是多行省略?

CSS定制文本省略的方法

 当字数多到一定程度就显示省略号点点点。最初只是简单的点点点,之后花样越来越多,点点点加下箭头,点点点加更多,点点点加更多加箭头…。多行省略就是大段文字后面的花式点点点。

同行这么做:

CSS定制文本省略的方法 

1.Google Plus用透明到白色的渐变遮罩,渐变遮罩在文字超出的时候才显示,但无法挤出文字,且背景只能纯色,不理想。
 

2.豌豆荚则更简单粗暴换行显示,换行显示则文字未超出时依然显示 …xxx,更不理想!

我们这样做:

立即学习“前端免费学习笔记(深入)”;

CSS定制文本省略的方法

 在QQ浏览器的页面用了一个原创的mod-more UI组件,实现了定制的多行省略,还是纯CSS的,领先同行一大截,赞!赞!赞!只可惜,mod-more组件的高度是固定的。对mod-more进一步进化,完美自适应高度,而且代码简化易用。

二、怎么做到的?

CSS定制文本省略的方法

定制多行省略 = 按需显示…更多 + 文字溢出截断,按需显示…更多是用浮动特性实现,文字溢出阶段可以用前置浮动和line-clamp实现,QQ浏览器现有方案就是前置浮动,但缺点是高度固定,使用line-clamp则自适应高度,完美!限于篇幅,这里只提line-clamp的实现方案,QQ浏览器将在下阶段升级至该方案。

原理详解!

按需显示…更多

CSS定制文本省略的方法

@-webkit-keyframes width-change {0%,100%{width: 320px} 50%{width:260px}}

腾讯成立于1998年11月,是目前中国领先的互联网增值服务提供商之一。成立10多年来,腾讯一直秉承“一切以用户价值为依归”的经营理念,为亿级海量用户提供稳定优质的各类服务,始终处于稳健发展状态。2004年6月16日,腾讯控股有限公司在香港联交所主板公开上市(股票代号700)。

placeholder

...更多

 

 

利用右浮动原理——右浮动元素从右到左依次排列,不够空间则换行。蓝色块、粉色块、橙色块依次右浮动,蓝色块高度小于6行文字时,橙色块在右边,蓝色块高度大于6行文字时,左下角刚好够橙色块排列的空间,于是橙色块就到左边了

 CSS定制文本省略的方法

@-webkit-keyframes width-change {0%,100%{width: 320px} 50%{width:260px}}

腾讯成立于1998年11月,是目前中国领先的互联网增值服务提供商之一。成立10多年来,腾讯一直秉承“一切以用户价值为依归”的经营理念,为亿级海量用户提供稳定优质的各类服务,始终处于稳健发展状态。2004年6月16日,腾讯控股有限公司在香港联交所主板公开上市(股票代号700)。

placeholder

...更多

 

 

进一步将橙色块偏移到正确位置就大功告成了!细心的同学会发现,将橙色块加上渐变底就是Google Plus在用的方案。

 文字溢出截断

CSS定制文本省略的方法

@-webkit-keyframes width-change {0%,100%{width: 320px} 50%{width:260px}}

腾讯成立于1998年11月,是目前中国领先的互联网增值服务提供商之一。成立10多年来,腾讯一直秉承“一切以用户价值为依归”的经营理念,为亿级海量用户提供稳定优质的各类服务,始终处于稳健发展状态。2004年6月16日,腾讯控股有限公司在香港联交所主板公开上市(股票代号700)。

 

 

 -webkit-line-clamp是webkit内核的私有css属性,用于进行多行省略,在安卓和ios上全支持。但它固定使用省略号,无法直接扩展。而且自带了溢出截断逻辑,作用于容器高度。仔细考察可发现它使用的省略号是单字符…,可以用文字css属性如font-size,letter-spacing,color等控制。

 CSS定制文本省略的方法

@-webkit-keyframes width-change {0%,100%{width: 320px} 50%{width:260px}}/*测试*/

腾讯成立于1998年11月,是目前中国领先的互联网增值服务提供商之一。成立10多年来,腾讯一直秉承“一切以用户价值为依归”的经营理念,为亿级海量用户提供稳定优质的各类服务,始终处于稳健发展状态。2004年6月16日,腾讯控股有限公司在香港联交所主板公开上市(股票代号700)。

 

 

 设置外容器的font-size、letter-spacing、color,并在子容器里恢复就可以单独设置省略号。这里外容器设置font-size的值等于2倍行高(余下要撑开的宽度可用letter-spacing补足,也可仅用font-size撑开全部的宽度),color为transparent就可以让line-clamp既挤出文字又不截断容器高度,外容器高度达到7行而不是默认表现的6行,从而达到需要的溢出截断效果

合体!定制多行省略

CSS定制文本省略的方法

@-webkit-keyframes width-change {0%,100%{width: 320px} 50%{width:260px}}/*测试*/

腾讯成立于1998年11月,是目前中国领先的互联网增值服务提供商之一。成立10多年来,腾讯一直秉承“一切以用户价值为依归”的经营理念,为亿级海量用户提供稳定优质的各类服务,始终处于稳健发展状态。2004年6月16日,腾讯控股有限公司在香港联交所主板公开上市(股票代号700)。

... 更多

 

 

将-webkit-line-clamp实现的文字溢出截断代码为主体,叠加绝对定位同步的按需显示…更多结构。因为绝对定位,这里使用百分比简化代码。最外包一层结构限制最大高度。

 CSS定制文本省略的方法

/* * 行高 h * 最大行数 n * ...更多容器的宽 w * 字号 f */@-webkit-keyframes width-change {0%,100%{width: 320px} 50%{width:260px}}.ellipsis {    position: relative;    background: rgb(230, 230, 230);    width: 260px;    max-height: 108px; /* h*n */    line-height: 18px; /* h */    overflow: hidden;    -webkit-animation: width-change 8s ease infinite;}.ellipsis-container {    position: relative;    display: -webkit-box;    -webkit-box-orient: vertical;    -webkit-line-clamp: 6; /* n */    font-size: 50px; /* w */    color: transparent;}.ellipsis-content {    color: #000;    display: inline;    vertical-align: top;    font-size: 12px; /* f */}.ellipsis-ghost {    position:absolute;    z-index: 1;    top: 0;    left: 50%;    width: 100%;    height: 100%;    color: #000;}.ellipsis-ghost:before {    content: "";    display: block;    float: right;    width: 50%;    height: 100%;}.ellipsis-placeholder {    content: "";    display: block;    float: right;    width: 50%;    height: 108px; /* h*n */}.ellipsis-more {    position: relative;    float: right;    font-size: 12px; /* f */    width: 50px; /* w */    height: 18px; /* h */    margin-top: -18px; /* -h */}

腾讯成立于1998年11月,是目前中国领先的互联网增值服务提供商之一。成立10多年来,腾讯一直秉承“一切以用户价值为依归”的经营理念,为亿级海量用户提供稳定优质的各类服务,始终处于稳健发展状态。2004年6月16日,腾讯控股有限公司在香港联交所主板公开上市(股票代号700)。

...更多

 

 

将橙色块偏移到正确位置,梳理了下代码,最终实现了自适应高度的定制多行省略,完美!从此妈妈再也不担心我在省略号后面加东西改东西了!恭喜你击败99%的同行了!

 三、为什么这么做?

line-clamp有3宗罪

CSS定制文本省略的方法

和 text-align:justify 一起用会使省略号和文字相叠

 CSS定制文本省略的方法

 超出截断后会截掉部分行高

 CSS定制文本省略的方法

 省略号出现在单词中间 

定制省略当然某问题啦

CSS定制文本省略的方法

ext-align:justify时如期所示,没问题!

CSS定制文本省略的方法 

截断时如期所示,也没问题!

CSS定制文本省略的方法 

省略号在有单词时如期显示,依然没问题!

更别说点点点花样增改

CSS定制文本省略的方法

CSS定制文本省略的方法

简单增改文字加链接只是小case

CSS定制文本省略的方法 

用折角还是其他图片表示文本溢出可以增添趣味

CSS定制文本省略的方法 

溢出时显示溢出字数增加了实用用途

CSS定制文本省略的方法 

相信看了本文案例你已经掌握了方法,更多精彩请关注创想鸟其它相关文章!
推荐阅读:

css的绝对定位怎么兼容所有的分辨率

css中属性值继承如何使用

以上就是CSS定制文本省略的方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1609417.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 00:46:35
下一篇 2025年12月16日 03:27:32

相关推荐

  • css中属性值继承如何使用

    这次给大家带来css中属性值继承如何使用,使用css中属性值继承的注意事项有哪些,下面就是实战案例,一起来看一下。 继承:html元素可以从父元素那里继承一部分css属性,即使当前元素没有定义该属性。 1.css可以和不可以继承的属性 不可继承的:display、margin、border、padd…

    好文分享 2025年12月24日
    000
  • 你不知道的冷门CSS属性

    你不知道的冷门CSS属性这次给大家带来,使用冷门CSS属性的注意事项有哪些,下面就是实战案例,一起来看一下。 每年都有新的CSS属性被标准化,并在主流浏览器中可用。 它们旨在使Web开发人员的工作变得轻松,创造出新颖美丽的网站。 在这篇文章中,我将介绍5个相对较新的CSS属性,你可能从来没有听说过,…

    2025年12月24日
    000
  • 用CSS3实现弹幕效果

    这次给大家带来用CSS3实现弹幕效果,用CSS3实现弹幕效果的注意事项有哪些,下面就是实战案例,一起来看一下。 最近需要项目需要实现弹幕,网上参考了各种方法,最后觉得transform+transition实现的效果在移动设备上性能最好,在iphone6和红米4上测试,看不到卡顿的感觉。用jquer…

    好文分享 2025年12月24日
    000
  • 用CSS实现页面的尖角、小三角、不同方向尖角

    这次给大家带来用CSS实现页面的尖角、小三角、不同方向尖角,用CSS实现页面的尖角、小三角、不同方向尖角的注意事项有哪些,下面就是实战案例,一起来看一下。 效果图: 方法一的效果图: 方法二的效果图: 方法三的效果图: 方法1:因为有背景,所有实现起来比较方便,尖角的内部同个颜色就可以不用考虑遮挡问…

    2025年12月24日 好文分享
    000
  • css3实现wifi信号形状

    这次给大家带来css3实现wifi信号形状,css3实现wifi信号形状的注意事项有哪些,下面就是实战案例,一起来看一下。 整理文档,搜刮出一个css3实现wifi信号逐渐增强效果实例的代码,稍微整理精简一下做下分享。 效果图 下面是实现代码: wifi信号 *{ margin: 0; paddin…

    2025年12月24日
    000
  • 怎样用CSS3来代替JS实现交互效果

    这次给大家带来怎样用CSS3来代替JS实现交互效果,用CSS3来代替JS实现交互效果的注意事项有哪些,下面就是实战案例,一起来看一下。 【CSS3和JS】 对于CSS了解的同学都知道,CSS的实现是最底层的,在实现方式和性能上都不是,JS这种提供接口的脚本可比的;从CSS3的动画和JS动画对比角度来…

    2025年12月24日
    000
  • css清除浮动float的兼容性方法

    这次给大家带来css清除浮动float的兼容性方法,css清除浮动float兼容性方法的注意事项有哪些,下面就是实战案例,一起来看一下。 在清除浮动前我们要了解两个重要的定义: 浮动的定义:使元素脱离文档流,按照指定方向发生移动,遇到父级边界或者相邻的浮动元素停了下来。 高度塌陷:浮动元素父元素高度…

    好文分享 2025年12月24日
    000
  • 用css3做出气球图片样式

    这次给大家带来用css3做出气球图片样式,用css3做出气球图片样式的注意事项有哪些,下面就是实战案例,一起来看一下。 气球效果图: html: css: .balloon{ width: 160px; height: 160px; background: #faf9f9; /*css3 圆角属性*…

    2025年12月24日
    000
  • css实现操作table列

    这次给大家带来css实现操作table列,css实现操作table列的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 最近在做的后台管理系统要处理大量的表格,因为原项目是采用的for循环加拼接字符串的方式实现;导致js代码一大堆;各种单引号和双引号的嵌套;让人头疼;遂引入vue.js;用v-…

    好文分享 2025年12月24日
    000
  • CSS图片下有间隙如何处理

    这次给大家带来CSS图片下有间隙如何处理,处理CSS图片下有间隙的注意事项有哪些,下面就是实战案例,一起来看一下。 在进行页面的p+CSS排版时,遇到IE6(当然有时Firefox下也会偶遇)浏览器中的图片元素img下出现多余空白的问题绝对是常见的对於 该问题的解决方法也是「见机行事」,根据原因的不…

    好文分享 2025年12月24日
    000
  • CSS鼠标悬浮无限生成下级页面

    这次给大家带来CSS鼠标悬浮无限生成下级页面,CSS鼠标悬浮无限生成下级页面的注意事项有哪些,下面就是实战案例,一起来看一下。 废话不多说了,直接大家贴代码了,具体代码如下所示; *{ margin: 0; padding: 0; } ul,li{ list-style: none; } .ui-s…

    2025年12月24日
    000
  • CSS怎样做出梯形的标签页

    这次给大家带来CSS怎样做出梯形的标签页,CSS做出梯形标签页的注意事项有哪些,下面就是实战案例,一起来看一下。 在web设计中,梯形标签页是很常见的一种形式,但是梯形又是一种很难实现的样式,很多开发者会直接用梯形背景图片来生成效果,但是采用背景图片的方式产生了额外的http请求,并不是一种非常理想…

    2025年12月24日 好文分享
    000
  • CSS生成常用的图标样式

    这次给大家带来CSS生成常用的图标样式,CSS生成常用的图标样式的注意事项有哪些,下面就是实战案例,一起来看一下。 基本图标: 您可以将Font Awesome图标使用在几乎任何地方,只需要使用CSS前缀 fa ,再加上图标名称。 Font Awesome是为使用内联元素而设计的。我们通常更喜欢使用…

    好文分享 2025年12月24日
    000
  • 常用的CSS实现垂直居中的4种方法

    这次给大家带来常用的CSS实现垂直居中的4种方法,CSS实现垂直居中的注意事项有哪些,下面就是实战案例,一起来看一下。 行高line-height实现单行文本垂直居中 以前一直认为单行文本垂直居中要将高度和行高设置成相同的值,但高度其实没必要设置。实际上,文本本身就在一行中居中显示。在不设置高度的情…

    2025年12月24日
    000
  • css如何做出0.5像素的线条

    这次给大家带来css如何做出0.5像素的线条,css做出0.5像素线条的注意事项有哪些,下面就是实战案例,一起来看一下。 公司的设计师在做设计图的时候都是以iphone6(宽为750物理像素)为基准进行设计的。iphone6的设备像素比(即css像素与物理像素的比例)是2,所以设计师在设计图画了边框…

    2025年12月24日
    000
  • css3的Transition平滑过渡菜单栏实现

    这次给大家带来css3的Transition平滑过渡菜单栏实现,实现Transition平滑过渡菜单栏的注意事项有哪些,下面就是实战案例,一起来看一下。 CSS3的制作动画的三大属性(Transform,Transition,Animation)下面介绍一下 Transition属性。transit…

    2025年12月24日
    000
  • CSS双飞翼布局的详解

    这次给大家带来CSS双飞翼布局的详解,实现CSS双飞翼布局的注意事项有哪些,下面就是实战案例,一起来看一下。 双飞翼布局,就是两端固定宽高,中间自适应的三栏布局 先来张图,左边和右边的灰色块是固定宽高的,中间绿色的区域是宽高自适应 方式一:通过flex弹性布局来实现 看代码 //HTML结构,p2是…

    2025年12月24日
    000
  • 怎样高效的使用CSS选择符

    这次给大家带来怎样高效的使用CSS选择符,高效使用CSS选择符的注意事项有哪些,下面就是实战案例,一起来看一下。 最初写CSS的时候,觉得很简单,写得天马行空。后来慢慢的发现,没有规则的瞎写,虽然也能实现效果,但是在实际开发中可能会多做无用功或是重复做功,并且CSS并不高效。于是后期开发时就特意按照…

    2025年12月24日
    000
  • CSS3实现瀑布流布局的方法

    这次给大家带来CSS3实现瀑布流布局的方法,CSS3实现瀑布流布局的注意事项有哪些,下面就是实战案例,一起来看一下。 以前使用瀑布流都要用js,现在有了css3,可以轻松实现了。 掌握点: 1、column-count 把p中的文本分为多少列 2、column-width 规定列宽 3、column…

    好文分享 2025年12月24日
    000
  • CSS3做出倒影的图文详解

    这次给大家带来css3做出倒影的图文详解,css3做出倒影效果的注意事项有哪些,下面就是实战案例,一起来看一下。 效果图如下: 示例图片 在CSS3之前,想要实现示例图片这样的一个倒影效果一般只能通过处理图片的方式,而CSS3问世之后,想要实现这样的效果变得非常简单,只需一个CSS3属性就可以轻松实…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信