为 Element UI 里的 autosize textarea 设置高度

Element UI 里的 textarea input 设置为 autosize 之后,文本框的默认高度为 33,并不符合设计


默认样式

在浏览器中查检元素,发现

  • 高度是由 textareaheightmin-height 来控制
  • 框内文字的位置是由 padding 控制

尝试

直接修改文本框的 heightpadding,看看能否起作用

全局样式里添加:

1
2
3
4
5
6
7
8
9
10
11
$inputHeight: 38px;
$inputFontSize: 16px;

.el-textarea {
textarea {
padding: 8px; // 设置文本框的 padding
height: $inputHeight; // 设置文本框的 height
font-size: $inputFontSize;
line-height: 21px;
}
}

改过之后发现:

  • padding 已经是新设置的大小了
  • height 并不是我设置的高度

有意思的是,这个文本框的 height 是由行内样式所控制

面对这个问题,我做了两个尝试

!important

height 设置为 !important ,高度是变了,但它不能自动扩展了

-> 放弃

MyTextarea

自己写 textarea 组件,这样一来样式是可以随意改了,但要实现文本框随内容扩展的话还得写一堆 js ,成本有点高

-> 不优先使用


padding 决定了 height

在调试过程中发现,Element UI 里的 autosize textarea 的初始高度是会随着 padding 的值变化

所以,我就在浏览器里调整 padding 的大小 ,直到它撑起来的高度和 figma 里要求的高度一致

然后把全局样式里的 padding 改成对应的值

1
2
3
4
5
6
7
8
9
$inputFontSize: 16px;

.el-textarea {
textarea {
padding: 7.5px 0 7.5px 8px; // 只要改变这里的 padding 就可以影响到 textarea 的高度
font-size: $inputFontSize;
line-height: 21px;
}
}

就实现了想要的效果


结论

想要自定义 autosize textarea 的高度的话,可以设置它的 padding 值,Element UI 会根据这个 padding 去添加相应的高度到元素上

原文作者: dgb8901,yinxing

原文链接: https://www.itwork.club/2020/05/29/set-height-of-elementui-autosize-textarea/

版权声明: 转载请注明出处

为您推荐

体验小程序「跟我记账」

关注公众号「特想学英语」

VS Code 常用快捷键