为 Element UI 里的 autosize textarea 设置高度
把 Element UI 里的 textarea input
设置为 autosize 之后,文本框的默认高度为 33
,并不符合设计
默认样式
在浏览器中查检
元素,发现
- 高度是由
textarea
的height
和min-height
来控制 - 框内文字的位置是由
padding
控制
尝试
直接修改文本框的 height
和 padding
,看看能否起作用
在全局样式
里添加:
1 | $inputHeight: 38px; |
改过之后发现:
padding
已经是新设置的大小了height
并不是我设置的高度
有意思的是,这个文本框的 height
是由行内样式所控制
面对这个问题,我做了两个尝试
!important
把 height
设置为 !important
,高度是变了,但它不能自动扩展了
-> 放弃
MyTextarea
自己写 textarea
组件,这样一来样式是可以随意改了,但要实现文本框随内容扩展
的话还得写一堆 js ,成本有点高
-> 不优先使用
padding 决定了 height
在调试过程中发现,Element UI
里的 autosize textarea
的初始高度是会随着 padding
的值变化
所以,我就在浏览器里调整 padding
的大小 ,直到它撑起来的高度和 figma
里要求的高度一致
然后把全局样式里的 padding
改成对应的值
1 | $inputFontSize: 16px; |
就实现了想要的效果
结论
想要自定义 autosize textarea
的高度的话,可以设置它的 padding
值,Element UI
会根据这个 padding
去添加相应的高度到元素上
原文作者: dgb8901,yinxing
原文链接: https://www.itwork.club/2020/05/29/set-height-of-elementui-autosize-textarea/
版权声明: 转载请注明出处
为您推荐
体验小程序「简易记账」
关注公众号「特想学英语」