单/多行文本添加省略号方法详解
1.单行文本添加省略号
一般用于新闻列表展示
li{ width: 200px; height: 30px; line-height: 30px; cursor: pointer; list-style-position: inside;/将列表图标位置设置为inside,默认outside,overflow值为hidden时会截取掉/ overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
小tip为添加省略号的文本标签添加title属性,值为完整文本,当用户鼠标停留在该文本时,会显示完整内容。
核心代码
overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
overflow 溢出
值
visible元素的内容在元素框之外也可见(溢出内容不被剪裁)
hidden元素的内容会在元素框的边界处剪裁,并且超出剪裁区域的内容不可见
scroll元素的内容会在元素框的边界处剪裁,但浏览器会显示滚动条以便查看其余的内容
auto 如果内容被剪裁,则浏览器会显示滚动条以便查看其余的内容
inherit
初始值visible
应用于块级元素、替换元素、表单元素
text-overflow 文本溢出
值
clip不显示省略标记(...),只是简单的裁切,相当于无效果
ellipsis文本溢出时显示省略标记(...),省略标记插入的位置是一个字符
初始值cilp
应用于块级元素、替换元素、表单元素
white-space 空白符
(空白符是指空格、制表符he回车;HTML默认将所有空白符合并为一个空格)
值
normal合并空白符,允许自动换行
nowrap合并空白符,不允许自动换行
pre-line合并空白符(不包括换行符),允许自动换行
pre不合并空白符,不允许自动换行
pre-wrap不合并空白符,允许自动换行
2.多行文本末显示省略号
① Webkit浏览器或移动端页面
p{ width: 200px;height:150px;border: 1px solid pink; line-height: 30px;cursor: pointer;padding: 0 5px; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 5; -webkit-box-orient: vertical;
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <body> <p title="Web 浏览器对于 ECMAScript 来说是一个宿主环境,但它并不是唯一的宿主环境。事实上,还有不计其数的其他各种环境(例如 Nombas 的 ScriptEase,以及 Macromedia 用在 Flash 和 Director MX 中的 ActionScript)可以容纳 ECMAScript 实现">Web 浏览器对于 ECMAScript 来说是一个宿主环境,但它并不是唯一的宿主环境。事实上,还有不计其数的其他各种环境(例如 Nombas 的 ScriptEase,以及 Macromedia 用在 Flash 和 Director MX 中的 ActionScript)可以容纳 ECMAScript 实现</p> </body> </html>
核心代码
{ overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 5; -webkit-box-orient: vertical; }
display-webkit-box;将对象作为弹性盒子模型显示。
-webkit-box-orient;设置或检索伸缩盒对象的子元素的排列方式。
-webkit-line-clamp;限制在一个块元素显示的文本的行数。
小tip该属性为webkit的私有属性,只适用于webkit内核浏览器或移动端。
② 跨浏览器兼容方案
②-1设置相对定位的容器高度,用包含省略号(...)的元素模拟实现
p{ width: 200px;height:150px;border: 1px solid pink;line-height: 30px;cursor: pointer;padding: 0 5px; overflow: hidden; position: relative; } span{ position: absolute; bottom: 0; right: 0; }
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <body> <p title="Web 浏览器对于 ECMAScript 来说是一个宿主环境,但它并不是唯一的宿主环境。事实上,还有不计其数的其他各种环境(例如 Nombas 的 ScriptEase,以及 Macromedia 用在 Flash 和 Director MX 中的 ActionScript)可以容纳 ECMAScript 实现">Web 浏览器对于 ECMAScript 来说是一个宿主环境,但它并不是唯一的宿主环境。事实上,还有不计其数的其他各种环境(例如 Nombas 的 ScriptEase,以及 Macromedia 用在 Flash 和 Director MX 中的 ActionScript)可以容纳 ECMAScript 实现<span>...</span></p> </body> </html>
②-2通过伪元素模拟添加省略号(...)
p{ width: 200px;height:150px;border: 1px solid pink; line-height: 30px;cursor: pointer;padding: 0 5px; overflow: hidden; position: relative; } p:after{ content: '...'; position: absolute; background:url(http://css88.b0.upaiyun./css88/2014/09/ellipsis_bg.png) repeat-y; bottom: 0; right: 0; }
小tip
a.height高度应是line-height的n(行数)倍;
b.结束的省略号可用半透明png做减淡效果,或者设置背景颜色;
c.IE6-7不显示content内容,解决方案如下
引入jquery和jquery.pseudo.js
p{ width: 200px;height:150px;border: 1px solid pink; line-height: 30px;cursor: pointer;padding: 0 5px; overflow: hidden; position: relative; } span{ after:'...'; position: absolute; right: 0; bottom: 0; }
3.JavaScript方案
a.Clamp.js
下载及文档地址
使用
var module = document.getElementById("clamp-this-module"); $clamp(module, {clamp: 3});
b.jQuery.dotdotdot
下载及详细文档地址或
使用
$(document).ready(function() { $("#wrapper").dotdotdot({ // configuration goes here }); });
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望多多支持狼蚁SEO!
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML