html加js和css实现一个文章过长隐藏折叠展开的功能
html加js和css实现一个文章过长隐藏折叠展开的功能
全部代码如下:
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>文章内容部分隐藏展开示例</title>
<style>
.more-content .hidden-parts {
font-size: 14px;
line-height: 40px;
margin: 0 auto;
color: #fff;
background: #6f98b0;
text-align: center;
height: 40px;
cursor: pointer;
width: 90%;
display: block;
border-radius: 50px;
}
.more-hidden {
overflow: hidden;
}
</style>
</head>
<body>
<div class="more-content">
<div class="more-hidden" id="unfold-fold">
<p>
这是文章的开头部分,
这是文章的开头部分,
这是文章的开头部分,
</p>
</div>
</div>
<script src="/jquery-3.6.0.min.js"></script>
<script>
$(document).ready(function() {
const content = $("#unfold-fold");
const openHeight = 100; // 初始显示高度
const totalHeight = content.height();
const segments = Math.ceil(totalHeight / openHeight);
if (segments > 1) {
content.css('maxHeight', `${openHeight}px`);
let currentSegment = 1;
// 创建并添加提示文本
const tipText = $('<div class="hidden-parts">点击展开,剩余 ' + (100 - (100 / segments * currentSegment)) + '% 未阅读</div>');
$(".more-content").append(tipText);
tipText.on("click", function() {
if (currentSegment < segments) {
currentSegment++;
const remainingPercent = Math.floor(100 - (100 / segments) * currentSegment);
content.css('maxHeight', `${openHeight * currentSegment}px`);
if (remainingPercent > 0) {
tipText.html(`点击展开,剩余 ${remainingPercent}% 未阅读`);
} else {
tipText.hide();
}
}
});
} else {
// 如果没有更多内容,则隐藏提示元素
$('<div class="hidden-parts">点击展开,剩余 0% 未阅读</div>').hide().appendTo(".more-content");
}
});
</script>
</body>
</html>
声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至201542412@QQ.com举报,一经查实,本站将立刻删除。
上一篇:bootstrap怎么写轮播图
下一篇:返回列表
相关推荐
-
PHP核心的扩展开发实践与技巧
核心的扩展开发实践与技巧在开发中,扩展是一种非常重要的技术手段。通过扩展,我们可以扩展的功能,提高代码的运行效率,实现一些无法实现的功能。本文将介绍核心的扩展开发实践与技
-
htm加css和js实现手机端隐藏查看剩余点击展开,剩余%未阅读
htm加css和js实现手机端隐藏查看剩余点击展开,剩余%未阅读js部分代码:html部分css部分:其中.rticl-body是第一内容元素,.contnt第二元素...