把Element UI里的textarea input
设置为autosize之后,文本框的默认高度为33
,并不符合设计
默认样式
在浏览器中查检
元素,发现
高度是由textarea
的height
和min-height
来控制框内文字的位置是由padding
控制尝试
直接修改文本框的height
和padding
,看看能否起作用
在全局样式
里添加:
$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
改成对应的值
$inputFontSize: 16px; .el-textarea { textarea { padding: 7.5px 0 7.5px 8px; // 只要改变这里的 padding 就可以影响到 textarea 的高度 font-size: $inputFontSize; line-height: 21px; } }
总结