React实现文本超出显示省略号和Tooltip,不超出不显示Tooltop,在table表格里也适用

本文介绍了一个使用React、antd和useState、useEffect构建的HoverTooltip组件,当内容超过容器宽度时,鼠标悬浮时显示tooltip并处理省略号显示和隐藏。
摘要由CSDN通过智能技术生成

效果:
在这里插入图片描述

代码:

import React, { useRef, useState, useEffect } from 'react';
import type { TooltipProps } from 'antd/lib/tooltip';
import { Tooltip } from 'antd';

/**
 * 超出宽度鼠标悬浮显示tooltip
 * @returns
 */
const HoverTooltip = (props: TooltipProps) => {
  const { title, children, ...rest } = props;
  const ref = useRef<HTMLDivElement>(null);
  // 是否显示tooltip
  const [show, setShow] = useState(false);
  // 显示省略号的样式
  const ellipsisStyle: React.CSSProperties = {
    overflow: 'hidden',
    textOverflow: 'ellipsis',
    whiteSpace: 'nowrap',
    display: 'inline-block',
    verticalAlign: 'middle',
    maxWidth: '100%',
  };

  // 判断是否需要显示省略号
  const isEllipsis = () => {
    const parentDom = ref.current;
    if (!parentDom) return false;
    const { offsetWidth, scrollWidth } = parentDom;
    return offsetWidth < scrollWidth;
  };

  useEffect(() => {
    // 设置父元素为hidden
    ref.current?.parentElement?.setAttribute('style', 'overflow: hidden;');
  }, [children]);

  useEffect(() => {
    setShow(isEllipsis());
  });

  return (
    <Tooltip title={show ? title || children : null} {...rest}>
      <div ref={ref} style={ellipsisStyle}>
        {children}
      </div>
    </Tooltip>
  );
};

export default HoverTooltip;


  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值