react 超一行展示省略号并且当鼠标悬浮时展示文本全部内容

2 篇文章 0 订阅
1 篇文章 0 订阅

Demo:

title 就是展示鼠标悬浮的内容,当title的值为undefined时 titile 不展示。

import { isExceed } from '@/utils/utils';
.....
<div className="col-item-value"  title={isExceed(props.value, 28)}>
   {props.value}
 </div>
....

需要分成两步:

Step1:css部分超一行展示省略号


.col-item-value {
	  overflow: hidden;
	  line-height: 35px;
	  white-space: nowrap;
	  text-overflow: ellipsis;
}

Step2:js部分鼠标悬浮展示文本内容

/**
 * 计算目标字符串是否超过特定字节长度
 * @param s:字符串
 * @param n:字节长度(1字符(中文)= 2字节,1字母/数字=1字节)
 * @param return 超过返回要展示的悬浮文本,否则返回undefined不展示悬浮文本
 * 适用:文本超一行(特定字节长度)展示省略号和悬浮文本
 */
export const isExceed = (str: string, n: number) => {
  const len = str?.replace(/[^\x00-\xff]/gi, '--').length; // 将中文汉字转换成字节并计算字节长度
  return len > n ? str : undefined;
};

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值