css 多行文字,超出部分隐藏,...代替

 css虽然简单,但其实也是记得常用的那些,不常用的还是要搜一搜再写?‍♀️

遇到了一个有意思的css问题,之前写过一行超出隐藏,倒是没写过多行超出隐藏

虽然很细节,但还是记一下备忘

 

一行一般是这么写的

p{
width:100px;
overflow:hidden;
white-space:no-wrap;
text-overfow:ellipsis;
}

但如果是多行,想要实现图二的效果,这样写是无法实现的

 

图1是两行文字,没有超出

 

图2 超出两行

<p>我超过两行啦啦啦哈哈哈娃哈哈哇哈哈就是我我我我哈</p>

 

 css 用到了一个display:-webkit-box;的属性来实现

p{
width:100px;
overflow: hidden;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
}

 貌似这个只兼容webkit浏览器内核的,所以用的时候如果有兼容要求的话要注意

 

 

 

 

其他---加记一个css问题:自定义虚线的间距

设计图经常会有虚线连接线,但虚线的长度密集程度就不一样,border不能够满足美观需求,这时候可以用背景来画

width: 100%;
height: 1px;
background-image: linear-gradient(to right, #ccc 0%, #ccc 50%, transparent 50%);
background-size: 8px 1px;
background-repeat: repeat-x;

 

转载于:https://www.cnblogs.com/leiting/p/10758389.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想控制文字超出内容时的显示方式,可以使用CSS的text-overflow属性。text-overflow属性可以取以下三个值之一: 1. clip:超出内容的部分将会被剪切掉,不会显示。 2. ellipsis:超出内容的部分将会被省略号代替。 3. string:超出内容的部分将会被指定的字符串代替。 例如,你可以使用以下码将超出内容部分文字显示为“...”: ``` .overflow { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } ``` 如果你想要多行文字溢出时的显示方式,可以使用-webkit-line-clamp属性。但是,这个属性只在WebKit浏览器中生效,如果你需要兼容Firefox和IE,可以使用一些JavaScript库来实现,比如clamp.js。 以下是一个使用了clamp.js的例子: ``` <div class="clamp"> <p>多行文本溢出测试,这是第一行。</p> <p>这是第二行。</p> <p>这是第三行。</p> <p>这是第四行。</p> <p>这是第五行。</p> </div> .clamp { display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; -webkit-line-clamp: 3; /* 显示的行数 */ } /* 兼容 Firefox 和 IE */ .clamp p:last-child { margin-bottom: 0; } ``` 这段码会将文本框的高度限制在三行之内,并且超出部分会用省略号代替。同时,我们使用了-webkit-box-orient属性来设置文本的方向为垂直,-webkit-line-clamp属性来控制显示的行数。最后,我们使用了clamp.js库来兼容Firefox和IE浏览器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值