如何实现 textarea 的高度自适应功能

AI 概述
今天项目需求需要实现一个回复评论的页面,设计师给的初始界面就是一个只有一行的框。然后当时就想这个交互该怎么实现比较好,这个功能还比较常见,用来获取文本的长宽(避免了计算不准的问题),主要用于实现 textarea 自动变长。 可以看到在我们使用 textarea 的时候,有时候需要感知内容的高度,然后动态撑开。(ele...

今天项目需求需要实现一个回复评论的页面,设计师给的初始界面就是一个只有一行的框。然后当时就想这个交互该怎么实现比较好,这个功能还比较常见,用来获取文本的长宽(避免了计算不准的问题),主要用于实现 textarea 自动变长。

如何实现 textarea 的高度自适应功能

可以看到在我们使用 textarea 的时候,有时候需要感知内容的高度,然后动态撑开。(elementUI 的 textarea 就提供了 autosize 的功能。)

那我们也想实现这样的功能应该怎么办呢?

  1. 获取内容,然后统计字符个数估算。中文算两个,英文算一个。但是还是有问题的,比如说非等宽字体。
  2. 聪明的读者已经看到了我们中间的 div 效果,就是我们想要的高度。也是 elementUI 的方案,创建一个拥有相同样式的 div,然后获取他的高度

构建相同样式的 DOM

看上去这个方案是最妙的。那么如何构建相同的 DOM 呢?

  1. 既然要构建相同的 DOM,那么我们需要知道 DOM 长什么样子
    那么如何获取样式呢?获取 class?获取 style?
    nonono,我们要用 window.getComputedStyle(el),然后就可以快乐的拿到计算后的属性。
  2. 之后我们需要知道什么属性会影响字体排列
    CONTEXT_STYLE = [ 'letter-spacing', 'line-height', 'padding-top', 'padding-bottom', 'font-family', 'font-weight', 'font-size', 'text-rendering', 'text-transform', 'width', 'text-indent', 'padding-left', 'padding-right', 'border-width', 'box-sizing']
  3. 因为我们需要重新搞一个 DOM 节点,而且我们不希望这个过程被用户看到,所以我们要隐藏起来。有什么方案呢?
    • display:none 这个是不行的,因为 none 之后不会绘制了。也就获取不到宽高了。
    • opacity:0 这个可以
    • visibility: hidden; 这个也可以
    • height:0;overflow:hidden 这个也可以,获取 scrollHeight
    • z-index:-999 这也可以的。
    • position:absolute;top:-9999px;left:-9999px 也是可以的

elementUI 实现

点击这里

以上关于如何实现 textarea 的高度自适应功能的文章就介绍到这了,更多相关内容请搜索码云笔记以前的文章或继续浏览下面的相关文章,希望大家以后多多支持码云笔记。

「点点赞赏,手留余香」

1

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » 如何实现 textarea 的高度自适应功能

发表回复