Taro多行文本最多展示5行,超出“查看更多”展示,点击弹层

Taro中,页面需求:

多行文本,展示最多展示5行,超出5行,展示"查看更多"按钮,点击弹层展示文本详细信息。

弹层代码就不说了,着重说一下怎么获取区域高度~

1.区域设置max-height,用于控制展示区域,最多5行

2.文本区域设置id名称,通过createSelectorQuery方法获取区域高度

3.文本设置line-height高度,乘以5

4.超出则说明文本展示已高于5行

bash 复制代码
initPageHeight = () => {
    setTimeout(() => {
      if (process.env.TARO_ENV === 'weapp') {
        createSelectorQuery()
          .select('#ruleText')
          .boundingClientRect((res) => {
            if (res) {
              const lineHeight = getPx(36);
              //默认展示5行,点击查看更多
              this.setState({ showMore: res.height > lineHeight * 5 });
            } else {
              this.initPageHeight();
            }
          })
          .exec();
      } else if (process.env.TARO_ENV === 'alipay') {
        const query = createSelectorQuery();
        query.select('#ruleText').boundingClientRect();
        query.exec((res) => {
          const height = res?.[0]?.height;
          if (height) {
            const lineHeight = getPx(36);
            this.setState({ showMore: res.height > lineHeight * 5 });
          }
        });
      }
    }, 400);
  };

示例图如下

相关推荐
kvo7f2JTy3 分钟前
基于机器学习算法的web入侵检测系统设计与实现
前端·算法·机器学习
北风toto5 分钟前
前端CSS样式详细笔记
前端·css·笔记
倔强的石头_7 分钟前
从 “不得不存” 到 “战略必争”:工业数据的价值觉醒之路
数据库
nanfeiyan15 分钟前
git commit
前端
倔强的石头_22 分钟前
新型电力系统应该用什么数据库?——时序数据库选型与落地实战
数据库
南汐以墨1 小时前
一个另类的数据库-Redis
数据库·redis·缓存
RInk7oBjo1 小时前
spring-事务管理
数据库·sql·spring
希望永不加班1 小时前
SpringBoot 数据库连接池配置(HikariCP)最佳实践
java·数据库·spring boot·后端·spring
黑牛儿2 小时前
MySQL 索引实战详解:从创建到优化,彻底解决查询慢问题
服务器·数据库·后端·mysql
捧月华如2 小时前
RAG 入门-向量存储与企业级向量数据库 milvus
数据库·milvus