多行文本溢出

问题描述

我想实现的效果是当前div的文本内容超过2行时,用...来代替剩余未显示的部分

矛盾点

网上介绍了一种很二B实现多行文本溢出的方法,虽然很二,还是决定试一试

.test {
    background-color: red;
    width: 60px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

我在纯的html文件中测试过,ok,是没有问题的,但在项目中却不能实现,后面没有....显示

问题解决

Q1:为什么会没有显示?
A1:打开浏览器的控制台,发现浏览器根本就没有识别到属性-webkit-box-orient: vertical;
为什么会识别不到这个属性呢?

  • 首先这个方法可以在WebKit浏览器或移动端(绝大部分是WebKit内核的浏览器)的页面,我用的是chrome浏览器,所以它是实现的
  • -webkit-line-clamp:2用来限制在一个块元素显示的文本的行数为2,它常见结合属性:
    • display: -webkit-box; 必须结合的属性 ,将对象作为弹性伸缩盒子模型显示
    • -webkit-box-orient 必须结合的属性 ,设置或检索伸缩盒对象的子元素的排列方式
    • text-overflow: ellipsis;,可以用来多行文本的情况下,用省略号“…”隐藏超出范围的文本

Q2: 怀疑是浏览器缓存的原因?
A2:手动清除了浏览器的缓存不行,又手动重新打包,然后重新集成到后端,还是不行。


Q3: 这个属性不能被浏览器识别,我查看了打包后的css代码,果然打包后的代码中是没有这个属性的,现在就有两种可能:

  • 用create-react-app 创建的项目中不能打包-webkit-box-orient: vertical;这个属性,项目框架本省的问题。
  • 用ant-design 后,Ant-design 内部的某个属性将这个属性给覆盖了

A3:本地重新用create-react-app 创建了一个项目进行尝试,没有引入库ant-design,结果发现在html中ok的但在这里仍旧不行。好了,找到问题了是在这里。网上搜索,在这里找到了答案


Q4:前面说这是一个二B 的方法,为什么呢?
A4: 首先使用的属性是-webkit-line-clamp;注意:这是一个 不规范的属性,它没有出现在 CSS 规范草案中。再者,它存在浏览器的兼容性问题.这种方式可能是更靠谱点的方法:

.test {
    position:relative;
    line-height:1.4em;
    /* 3 times the line-height to show 3 lines */
    height:4.2em;
    overflow:hidden;
}
.test::after {
    content:"...";
    font-weight:bold;
    position:absolute;
    bottom:0;
    right:0;
    padding:0 20px 1px 45px;
    background:url(http://newimg88.b0.upaiyun.com/newimg88/2014/09/ellipsis_bg.png) repeat-y;
}

反思

开始遇到这个问题的时候,网上各种搜索,结果都搜索不到,折腾了好久都没有解决。最后,跳过了这个问题,用js的方法解决了我的问题。过了一天,回过头来再来啃这个问题,用create-react-app 写demo尝试,才发现了问题,根据问题才搜索到原因。

action

  • 找原因,如果不能确定,不妨各种尝试,写demo去发现和证明
  • 搜索,不知道原因漫无目的的搜索不过是浪费时间而已。
  • 给自己限定解决问题的时间,如果一个小时还是没有任何的头绪,暂时放弃,换个时间再来看这个问题,说不定会有新的思路。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,529评论 5 475
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,015评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,409评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,385评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,387评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,466评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,880评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,528评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,727评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,528评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,602评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,302评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,873评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,890评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,132评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,777评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,310评论 2 342

推荐阅读更多精彩内容