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>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值