如何实现一个 autoSize 的 textarea

前言

熟悉 ant-design-vue 的小伙伴应该知道,<a-textarea auto-size /> 可以渲染出一个自适应高度的 textarea(即:高度随着内容的变化而变化);本文将介绍一下这样一个功能是如何实现的。

实现思路

如果我们能够实时的知道 textarea 元素中文本的高度,那么这个功能就很好实现了,只需要实时的将文本的高度赋值给 textarea 元素即可。

但是如何能够实时的知道 textarea 元素中文本的高度呢?这好像并不容易实现,那么我们可以换一种思路,如果有另外一个隐藏起来的 textarea(后文简称 hiddenTextarea), 它的所有尺寸相关 css 属性都与原本的 textarea 保持一致且文本内容也一致,那么这个需求就有可能可以实现;但问题在于 textarea 文本超出高度后会显示滚动条,而不是像其他普通元素一样更新元素的高度(如果是这样,那本文也没必要存在了[手动狗头])。

DOM 中有一个属性叫做 scrollHeight,我们可以获取 hiddenTextareascrollHeight 属性,将它的值赋值给原本 textareaheight 属性,那就实现了这个需求;接下来我们来看看具体如何实现。

实现

  1. 首先需要创建一个 hiddenTextarea,同时保证其尺寸相关的 css 属性都与原本的 textarea 保持一致,我们先来看看有哪些属性是与尺寸相关的:
ts 复制代码
const SIZING_STYLE = [
  'letter-spacing',
  'line-height',
  'padding-top',
  'padding-bottom',
  'font-family',
  'font-weight',
  'font-size',
  'font-variant',
  'text-rendering',
  'text-transform',
  'width',
  'text-indent',
  'padding-left',
  'padding-right',
  'border-width',
  'box-sizing',
  'word-break',
];

只需要将两个 textarea 的这些属性保持一致,那么他们的尺寸就会保持一致。

  1. 通过 window.getComputedStyle 方法获取原本 textarea 的属性值。
ts 复制代码
const style = window.getComputedStyle(textarea)
const sizingStyle = SIZING_STYLE.map(prop => `${prop}: ${style.getPropertyValue(prop)}`).join(';')
  1. 将属性值设置到 hiddenTextarea 上:
ts 复制代码
hiddenTextarea.setAttribute('style', `${sizingStyle};`);
  1. 获取 hiddenTextareascrollHeight 赋值给 textareaheight
ts 复制代码
textarea.style.height = hiddenTextarea.scrollHeight

如此,就实现了一个自适应高度的 textarea

结语

本文主要介绍了如何实现 textarea 自适应高度的原理。

相关推荐
A黄俊辉A14 小时前
vue css中 :global的使用
前端·javascript·vue.js
小码哥_常14 小时前
被EdgeToEdge适配折磨疯了,谁懂!
前端
小码哥_常14 小时前
从Groovy到KTS:Android Gradle脚本的华丽转身
前端
灵感__idea14 小时前
Hello 算法:复杂问题的应对策略
前端·javascript·算法
chushiyunen15 小时前
python中的内置属性 todo
开发语言·javascript·python
麦麦鸡腿堡15 小时前
JavaWeb_请求参数,设置响应数据,分层解耦
java·开发语言·前端
soso196815 小时前
JavaScript性能调优实战案例
javascript
Dxy123931021616 小时前
CSS常用样式详解:从基础到进阶的全面指南
前端·css
IT_陈寒16 小时前
SpringBoot自动配置揭秘:5个让开发效率翻倍的隐藏技巧
前端·人工智能·后端
Moment16 小时前
前端工程化 + AI 赋能,从需求到运维一条龙怎么搭 ❓❓❓
前端·javascript·面试