el-tooltip 如果文字太长,显示....鼠标移上去显示气泡,气泡内显示全部文字

组件 tooltipOver.vue


<template>
  <div class="text-tooltip">
    <el-tooltip class="item" effect="dark" :disabled="isShowTooltip" :content="content" placement="top">
      <p class="over-flow"  @mouseover="onMouseOver(refName)">
        <span :ref="refName">{{content}}</span>
      </p>
    </el-tooltip>
  </div>
</template>
 
<script>
  export default {
    name: 'textTooltip',
    props: {
      // 显示的文字内容
      content: {
        type: String,
        default: () => {
          return ''
        }
      },
      refName: {
        type: String,
        default: () => {
          return ''
        }
      }
    },
    data() {
      return {
        isShowTooltip: true
      }
    },
    methods: {
      onMouseOver(str) {
        const parentWidth = this.$refs[str].parentNode.offsetWidth;
        const contentWidth = this.$refs[str].offsetWidth;
        // 判断是否开启tooltip功能
        if (contentWidth>parentWidth) {
          this.isShowTooltip = false;
        } else {
          this.isShowTooltip = true;
        }
      }
    }
  }
</script>
 
<style scoped>
.over-flow {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  margin: 0px;
}
</style>

使用:

 <el-form-item 
                label-position="right"
                label-width="110px"
                label="XXX:"
                prop="xxx"
                class="readonly">
             <tooltip-over :content="dataAddForm.xxx"
                           :refName="'xxx'"></tooltip-over>
import tooltipOver from '@/components/tooltipOver/tooltipOver.vue'
...
 components: { tooltipOver },
....
<style scoped lang="scss">
.readonly {
  overflow-x: auto;
  /deep/ .el-form-item__content {
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
  }
}
</style>
Element UI的`el-table`组件中,如果你想在`show-overflow-tooltip`属性显示溢出提示时,向弹出的气泡(`el-tooltip__popper`)添加自定义CSS类,你可以通过`tooltip-class`选项来实现。这个选项允许你在触发提示时动态设置`el-tooltip`的额外CSS类。 下面是一个示例: ```html <template> <el-table :data="tableData" :show-overflow-tooltip="shouldShowTooltip"> <!-- ... --> <el-table-column tooltip-class="custom-tooltip-class" property="title" show-overflow-tooltip></el-table-column> <!-- ... --> </el-table> </template> <script> export default { data() { return { tableData: [], // 你的数据 shouldShowTooltip: false, // 这里可以根据需要动态设置 }; }, methods: { handleMouseEnter(row) { this.shouldShowTooltip = true; // 当鼠标进入行时,给el-tooltip__popper添加自定义类 const tooltip = document.querySelector('.el-tooltip__popper'); if (tooltip) { tooltip.classList.add('your-custom-class'); } }, handleMouseLeave() { this.shouldShowTooltip = false; // 鼠标离开时移除自定义类 const tooltip = document.querySelector('.el-tooltip__popper'); if (tooltip) { tooltip.classList.remove('your-custom-class'); } }, }, }; </script> <style scoped> .custom-tooltip-class { /* 定义你的自定义样式 */ color: red; background-color: yellow; } </style> ``` 在这个例子中,当鼠标进入表格行时,`handleMouseEnter`方法会设置`shouldShowTooltip`为真,并给`el-tooltip__popper`添加`custom-tooltip-class`类。当你不再需要这个提示时,`handleMouseLeave`会在鼠标离开时移除该类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值