单行文本溢出
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
p {
width: 200px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
</style>
</head>
<body>
<p>秦时明月汉时关,万里长征人未还</p>
</body>
</html>
多行文本溢出
这种方式兼容性不好,只能在 webkit 内核的浏览器中有效果(谷歌),手机端
<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.text {
width: 200px;
overflow: hidden;
text-overflow: ellipsis;
/*将对象作为弹性伸缩盒子模型显示 */
display: -webkit-box;
/*第几行打点*/
-webkit-line-clamp: 4;
/* 设置或检索伸缩盒对象的子元素的排列方式 */
-webkit-box-orient: vertical;
}
</style>
</head>
<body>
<div class="text">
故事背景取自秦灭六国到西楚霸王项羽灭秦这段英雄辈出的历史时期,时间跨度约30年,是一部以武侠为主题的全民型动画。各种历史事件和民间传说纷呈迭起,仗剑游走江湖的名士侠隐和对现代中国产生深远影响的诸子百家更是在这个合纵连横的大时代中悉数登场。
</div>
</body>
</html>
js做一个简单的封装
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<p>故事背景取自秦灭六国到西楚霸王项羽灭秦这段英雄辈出的历史时期,时间跨度约30年,是一部以武侠为主题的全民型动画。各种历史事件和民间传说纷呈迭起,仗剑游走江湖的名士侠隐和对现代中国产生深远影响的诸子百家更是在这个合纵连横的大时代中悉数登场。</p>
<script>
function ellipsis(num) {
let box = document.getElementsByTagName('p')[0];
let text = box.innerHTML;
if (text.length > num) {
let temp = text.split("").splice(0, num).join("") + '...';
box.innerHTML = temp;
return;
}
box.innerHTML += '...';
}
ellipsis(30);
</script>
</body>
</html>