技术文摘
父元素内子元素两行排列、超出隐藏且显示省略号按钮的实现方法
2025-01-09 14:49:12 小编
在前端开发中,实现父元素内子元素两行排列、超出隐藏且显示省略号按钮的效果,能有效提升页面布局的美观与信息展示的合理性。以下将详细介绍这一效果的实现方法。
HTML结构搭建是基础。我们需要创建一个父元素,在其中放置多个子元素。例如:
<div class="parent">
<div class="child">这里是子元素的内容,可能比较长,会超出两行</div>
<div class="child">另一个子元素内容</div>
</div>
接着,通过CSS来实现核心样式。对于父元素,设置宽度和高度以限定其显示范围,并开启溢出隐藏功能,确保超出部分不显示。例如:
.parent {
width: 300px;
height: 60px; /* 根据两行文字高度设置 */
overflow: hidden;
position: relative;
}
对于子元素,要实现两行排列,可使用弹性布局或浮动布局。这里以弹性布局为例:
.child {
display: flex;
flex-wrap: wrap;
line-height: 30px; /* 每行文字高度 */
max-height: 60px; /* 两行文字总高度 */
overflow: hidden;
text-overflow: ellipsis;
white-space: normal;
}
其中,text-overflow: ellipsis 是关键,它能让超出的文字显示为省略号。但此时省略号在内容中间,不太美观,我们还需进一步处理。
为了显示省略号按钮,我们可以在父元素内添加一个伪元素,模拟按钮效果。例如:
.parent::after {
content: '...';
position: absolute;
bottom: 0;
right: 0;
background-color: white;
padding: 0 5px;
}
这样,一个简单的省略号按钮就显示出来了。但在实际应用中,可能还需要添加交互效果,比如点击按钮展开全部内容。这可以通过JavaScript来实现。
const parent = document.querySelector('.parent');
const child = document.querySelector('.child');
parent.addEventListener('click', function() {
if (child.style.maxHeight === '60px') {
child.style.maxHeight = 'none';
} else {
child.style.maxHeight = '60px';
}
});
通过上述HTML、CSS和JavaScript的配合使用,就能完美实现父元素内子元素两行排列、超出隐藏且显示省略号按钮的效果,为用户带来更好的视觉体验。
- 并发编程中抽象队列同步器 AQS 在 ReentrantLock 中的应用
- 阿里双 11 突遇断网断电 惊险一幕被曝光
- Vue3 开发小程序的实际代码案例在此
- 一夜奋战,Python 助力我打造垃圾分类器!
- 优化 Docker 镜像与加速应用部署的小窍门
- Java 基础之 For 循环入门
- Spring AOP 的常见陷阱:多数人曾中招
- FreeRTOS 及其应用基础入门:万字长文解析
- Python 神操作:使图片人物动起来!
- 一次因线程池运用不当导致的线上事故
- 10 个实用的 CSS 代码片段分享
- Python 鲜为人知的五个隐藏特性
- 为何选择 Java 开发高频交易系统
- 低代码崛起,程序猿该拒绝还是拥抱
- Python 渐失光芒