公共tooltip组件

该文章介绍了一个使用Vue.js编写的公共Tooltip组件,旨在处理文本内容超出显示的问题。组件通过isShowTooltip函数判断内容是否超过指定宽度,并据此控制Tooltip的显示。组件内包含了元素定位、文本溢出隐藏和自定义样式等特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

公共tooltip组件,超出显示

<!-- 公共tooltip组件 -->
<template>
  <el-tooltip
    :disabled="controlElToop"
    :content="name"
    placement="top"
    :enterable="false"
  >
    <div
      class="researcher-name"
      :style="{width: boxWidth, textAlign: textAlign}"
    >
      <div
        ref="empty"
        class="empty"
      >
        {{ name }}
      </div>
      <span ref="contentVal">{{ name }}</span>
    </div>
  </el-tooltip>
</template>

<script>
import { isShowTooltip } from '@/utils/validate'

export default {
  name: 'KToolTip',
  props: {
    name: {
      type: String,
      default: '',
    },
    textAlign: {
      type: String,
      default: 'right',
    },
    boxWidth: {
      type: String,
      default: '57px',
    },
    width: {
      type: Number || String,
      default: 0,
    },
  },
  /** 初始参数 */
  data () {
    return {
      controlElToop: true,
    }
  },
  /**
   * 生命周期
   */
  mounted () {
    this.controlElToop = !isShowTooltip(this, 'empty', this.width)
  },
}
</script>

<style lang='scss' scoped>

.researcher-name {
  font-size: 14px;
  padding-right: 5px;
  color: #3C4455;
  position: relative;

  .empty {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }

  span {
    display: inline-block;
    width: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }
}
</style>

isShowTooltip

/** 验证文本内容是否超出容器,显示提示语 */
export function isShowTooltip (that, refValue, width) {
  return that.$refs[refValue].offsetWidth >= width
}
### 修改 Element UI Tooltip 组件的宽度 为了自定义 Element UI 中 `Tooltip` 组件的宽度,通常有两种方法:全局样式覆盖和局部样式调整。 #### 方法一:全局样式覆盖 如果希望在整个应用范围内统一修改 `Tooltip` 的最大宽度,则可以在项目的公共样式文件中添加特定的选择器: ```css .el-tooltip__popper { max-width: 50%; /* 可根据实际需求设定具体数值 */ } ``` 这种方法适用于所有使用默认类名 `.el-tooltip__popper` 的地方[^3]。需要注意的是,在 Vue 单文件组件内采用 `<style scoped>` 方式定义时,上述 CSS 不会生效于由框架动态生成的内容上;因此建议移除 `scoped` 属性或将此部分样式放置到非作用域样式的外部样式表中。 #### 方法二:局部样式调整 对于仅需针对某个特定实例或页面做个性化处理的情况,推荐利用嵌套的方式指定更具体的路径来避免影响其他区域: ```html <div class="custom-tooltip-container"> <!-- Table component here --> </div> ``` 配合相应的 SCSS 或者 LESS 文件中的代码片段: ```scss .custom-tooltip-container { .el-tooltip__popper.is-dark, .el-tooltip__popper.is-light { max-width: 80%!important; } } ``` 这里通过增加父级容器的选择权重确保了即使存在相同优先级的竞争也能正确应用新的宽度设置[^4]。同时,加上 `!important` 关键字可以强制覆盖原有样式声明[^5]。 无论是哪种方式,都应考虑到不同屏幕尺寸下的用户体验,适当测试并优化弹层在各种设备上的表现效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值