鸿蒙开发实践——基于measure实现的文本测量

场景描述

  • 场景一:当文本的内容超过指定的行数时显示 ...展开,当所有文本展开后,最后面跟着收起。

  • 场景二:搜索框展示历史记录,单个子组件超过固定长度后展示省略号,固定只展示两行,超出的文字被截断,通过点击按钮展示后续文本内容

方案描述

场景一:

当文本的内容超过指定的行数时显示 ...展开,当所有文本展开后,最后面跟着收起

方案

1、文本默认超过两行时,直接截断,在截断文本后添加...展开

 2、测量两行文本和全部文本的高度,当全部文本的高度超过两行文本的高度时进行展开的逻辑

 3、文本全部展开后,点击收起,所有文本全部收齐变成固定的两行

核心代码

文本收起态(即展开逻辑)

collapseText(): void {
  //判断文本是否需要展开
  if (!this.needProcess) {
    return;
  }
  let titleSize : SizeOptions = measure.measureTextSize({
    textContent: this.rawTitle,
    constraintWidth: this.titleWidth,
    fontSize: 20
  })
  //测量最大行数(两行)限制的高度,
  let twoLineSize : SizeOptions = measure.measureTextSize({
    textConten
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值