CSS文字溢出显示省略号,且出现title或者tooltip

简介: CSS文字溢出显示省略号,且出现title或者tooltip

背景


当文字溢出时显示省略号是每一个前端开发工程师必备技能之一,但是文字溢出省略号显示后就无法看到完整内容了,这个时候就可以用到标签的title属性,或者一些UI组件库的tooltip组件,当鼠标移入元素则出现提示气泡,显示完整内容。


前端工程师常见的作法就是让提示气泡一直存在,不管文字是否溢出,鼠标移入都会出现提示气泡。但是有些场景下,需求方要求文字未溢出时鼠标移入不显示提示气泡,文字溢出时才显示提示气泡。


需求总结


文字未溢出时,鼠标移入不出现提示气泡,文字溢出时,鼠标移入显示提示气泡。


实现原理


  1. 获取到包裹文字元素的宽度
  2. 给元素添加鼠标移入事件
  3. 每次鼠标移入时,判断元素宽度是否符合要求
  4. 如果不符合,则添加气泡,否则不添加


实现代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>CSS文字溢出显示提示title或者tooltip</title>
    <style>
        div {
            width: 100px;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
    </style>
</head>
<body>
    <div>
        <span>我是一段没有用的废话!</span>
    </div>
</body>
<script>
    let dDom = document.getElementsByTagName('div')[0];
    let sDom = document.getElementsByTagName('span')[0];
    let dDomWidth = sDom.parentNode.offsetWidth;
    let sDomWidth = sDom.offsetWidth;
    sDom.addEventListener('mouseover', function () {
        if (sDomWidth > dDomWidth) {
            sDom.title = '我是一段没有用的废话!'
        }
    })
</script>
</html>


总结


实现该种需求的重点就是获取到元素宽度,以及合理的判断宽度。

4.png


相关文章
|
2月前
|
前端开发
前端基础(五)_CSS文本文字属性、背景颜色属性
本文详细介绍了CSS中关于文本和背景颜色的样式属性。包括字体大小、字体族、字体加粗、字体样式、文本行高、`font`属性、文本颜色、文本对齐方式、文本装饰线、首行缩进等文本属性,以及背景颜色、背景图片、背景重复、背景位置等背景属性。文章通过示例代码展示了这些属性的具体应用和效果。
34 3
前端基础(五)_CSS文本文字属性、背景颜色属性
|
3月前
|
前端开发
简单几行代码CSS实现网页自动打文字效果
简单几行代码CSS实现网页自动打文字效果
56 1
简单几行代码CSS实现网页自动打文字效果
|
2月前
|
前端开发
css中的多行省略和单行省略
css中的多行省略和单行省略
|
1月前
|
Web App开发 前端开发 iOS开发
|
2月前
|
前端开发
css中的多行省略和单行省略
css中的多行省略和单行省略
|
3月前
|
前端开发 程序员
HTML+CSS+JavaScript制作动态七夕表白网页(含音乐+自定义文字)
一年一度的520情人节/七夕情人节/女朋友生日/程序员表白,是不是要给女朋友或者正在追求的妹子一点小惊喜呢,今天这篇博客就分享下前端代码如何实现HTML+CSS+JavaScript制作七夕表白网页(含音乐+自定义文字)。赶紧学会了,来制作属于我们程序员的浪漫吧!
86 0
HTML+CSS+JavaScript制作动态七夕表白网页(含音乐+自定义文字)
|
3月前
|
前端开发
CSS流光文字效果:打造网页上的霓虹灯效果!
CSS流光文字效果:打造网页上的霓虹灯效果!
|
3月前
|
前端开发
2s 利用 HTML+css动画实现企业官网效果
2s 利用 HTML+css动画实现企业官网效果
HTML+CSS 实现通用的企业官网页面(记得收藏)
HTML+CSS 实现通用的企业官网页面(记得收藏)