判断css文字发生了截断,增加悬浮提示

示例:

固定显示宽度,溢出显示...,利用了css的属性,想要实现成下面这样:

针对溢出的文字,hover显示全部。

提示很好加,使用tooltip组件就行了,难点是如何判断是否发生了文字溢出。

利用dom元素的可视宽度 clientWidth实际宽度 scrollWidth 不同就可以比较出是否发生了文字溢出。

实际宽度 > 可视宽度 = 文字溢出

那么就可以依此来判断,如下图所示,给各行增加ref属性,鼠标移入时判断是否显示对应行的提示信息。

我这里之所以鼠标移入时触发计算,是因为我卡片的宽度是动态变化的,若你那块内容宽度固定,可以在数据获取完成之后直接计算showTooltipObj的值。

全部代码如下图所示:

html 复制代码
<template>
  <div class="card">
    <ul>
      <li v-for="(item, index) in rows" :key="item.key" class="content">
        <b>{{ item.label }}:</b>
        <el-tooltip
          effect="dark"
          placement="top"
          :disabled="!showTooltipObj[index]"
          max-width="600px"
        >
          <div slot="content">
            <span>{{ data[item.key] || '--' }}</span>
          </div>
          <span
            :ref="`rowValue${index}`"
            class="value"
            @mouseenter="mouseenterFn(index)"
          >
            <span>{{ data[item.key] || '--' }}</span>
          </span>
        </el-tooltip>
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  // eslint-disable-next-line vue/multi-word-component-names
  name: "Card",
  data() {
    // 这里存放数据
    return {
      rows: [
        {
          label: "姓名",
          key: "name",
        },
        {
          label: "年龄",
          key: "age",
        },
        {
          label: "爱好",
          key: "hobby",
        }
      ],
      data: {
        name: "张三",
        age: 10,
        hobby: "吃饭、睡觉、打篮球、玩玩玩玩玩玩玩玩玩玩玩玩玩玩玩玩玩玩玩玩玩",
      },
      showTooltipObj: {},
    };
  },
  methods: {
    mouseenterFn(index) {
      this.$nextTick(() => {
        const dom = this.$refs[`rowValue${index}`][0];
        let flag = false;
        // 实际宽度 > 可视宽度  文字溢出
        if (dom.scrollWidth > dom.clientWidth) {
          flag = true;
        }
        this.$set(this.showTooltipObj, index, flag);
      });
    },
  },
};
</script>
<style lang='scss' scoped>
.card {
  margin: 40px;
  width: 400px;
  box-shadow: 0px 2px 10px 0px rgba(0, 0, 0, 0.16);
  border: 1px solid #d7d7d7;
  box-sizing: border-box;
  padding: 20px 0;
  li.content {
    margin: 0 20px;
    line-height: 22px;
    display: flex;
    b {
      white-space: nowrap;
    }
    .value {
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
  }
}
</style>
相关推荐
500佰2 分钟前
解读NotebookLM基于AI的PTT生成 程序化处理方法
前端·google·程序员
前端老宋Running2 分钟前
别再给组件“打洞”了:这才是 React 组件复用的正确打开方式
前端·javascript·前端框架
u***28473 分钟前
Spring Boot项目接收前端参数的11种方式
前端·spring boot·后端
pcm1235677 分钟前
java中用哈希表写题碰到的误区
java·前端·散列表
盗德11 分钟前
最全音频处理WaveSurferjs配置文档二(事件)
前端·javascript
恋猫de小郭15 分钟前
解读 Claude 对开发者的影响:AI 如何在 Anthropic 改变工作?
android·前端·ai编程
Evan芙16 分钟前
shell编程求10个随机数的最大值与最小值
java·linux·前端·javascript·网络
m0_7400437319 分钟前
Vue 组件及路由2
前端·javascript·vue.js
奋斗吧程序媛21 分钟前
Vue2 + ECharts 实战:动态一个关键词或动态多关键词筛选折线图,告别数据重叠难题
前端·javascript·echarts
黛色正浓29 分钟前
【React】极客园案例实践-项目搭建和登录模块
前端·react.js·rust