如何实现网页两行文本的ellipsis并跟随动态块状内容?
2024-11-23 19:00:54
0浏览
收藏
一分耕耘,一分收获!既然都打开这篇《如何实现网页两行文本的ellipsis并跟随动态块状内容? 》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新文章相关的内容,希望对大家都有所帮助!

如何在网页上实现两行文字ellipsis并跟随动态块状内容
本文旨在解决如何在网页上实现两行文本的ellipsis(省略号)并在其后紧随一个动态的块状内容。此效果可用于在不同文本长度下无缝衔接动态内容,例如图标或按钮。
解决方案:
可以使用以下 CSS 和少量 JavaScript 代码来实现这一效果:
p {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
display: inline-block;
max-width: 200px; // 根据需要调整最大宽度
}
.icon {
display: inline-block;
margin-left: 5px;
}function adjustIcons() {
var icons = document.querySelectorAll(".icon");
for (var i = 0; i < icons.length; i++) {
var icon = icons[i];
var parent = icon.parentNode;
var margin = parseFloat(window.getComputedStyle(icon).marginLeft);
var width = icon.offsetWidth + margin;
parent.style.width = (parent.offsetWidth - width) + "px";
}
}
window.addEventListener("load", adjustIcons);
window.addEventListener("resize", adjustIcons);演示效果:
[在线演示](https://codepen.io/xboxyan/pen/PopWVNX)
原理:
此解决方案利用 CSS 的 text-overflow: ellipsis 属性和 display: inline-block 属性来实现文本的ellipsis。max-width 属性则用于限制文本的宽度。
adjustIcons() 函数用于调整动态内容的位置,使其紧随ellipsis文本。它动态计算动态内容的宽度并相应调整其父元素的宽度。
此解决方案在各种浏览器中表现良好,并且可以轻松自定义以满足不同需求。
今天关于《如何实现网页两行文本的ellipsis并跟随动态块状内容? 》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
JavaScript中的"void 0"究竟代表什么?
- 上一篇
- JavaScript中的"void 0"究竟代表什么?
- 下一篇
- 在 React 中,如何为 map 循环创建的 div 添加行号?
查看更多
最新文章
-
- 文章 · 前端 | 1小时前 |
- JavaScript日期格式化方法全解析
- 325浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- HTML5边框定位不占位技巧
- 405浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- CSSLint优化技巧与样式提升方法
- 413浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- CSSSticky定位技巧:滚动与固定结合应用
- 293浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- 统一图标风格,FontAwesome全站应用指南
- 356浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- JavaScript动态加载模块技巧解析
- 119浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- LinuxHelix加速技巧与重构指南
- 182浏览 收藏
-
- 文章 · 前端 | 2小时前 | 顶层await
- 顶层await用法详解与实战技巧
- 288浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- 表单数据保留与自动清理技巧
- 120浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- EventLoop机制解析与执行顺序控制技巧
- 392浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- Tailwind任意值类解决方法详解
- 321浏览 收藏
-
2. CSS 样式使用 ::after 伪元素来在图片上叠加文字:
.im">

