[前端] 如何为 Element UI 里的 autosize textarea 设置高度

1947 0
王子 2022-10-19 15:36:20 | 显示全部楼层 |阅读模式
把Element UI里的textarea input设置为autosize之后,文本框的默认高度为33,并不符合设计
默认样式
在浏览器中查检元素,发现
高度是由textarea的height和min-height来控制框内文字的位置是由padding控制尝试
直接修改文本框的height和padding,看看能否起作用
在全局样式里添加:
  1. $inputHeight: 38px;
  2. $inputFontSize: 16px;
  3. .el-textarea {
  4.   textarea {
  5.     padding: 8px; // 设置文本框的 padding
  6.     height: $inputHeight; // 设置文本框的 height
  7.     font-size: $inputFontSize;
  8.     line-height: 21px;
  9.   }
  10. }
复制代码
改过之后发现:
    padding 已经是新设置的大小了height 并不是我设置的高度
有意思的是,这个文本框的height是由行内样式所控制
面对这个问题,我做了两个尝试
!important
把height设置为!important,高度是变了,但它不能自动扩展了
-> 放弃
MyTextarea
自己写textarea组件,这样一来样式是可以随意改了,但要实现文本框随内容扩展的话还得写一堆 js ,成本有点高
-> 不优先使用
padding 决定了 height
在调试过程中发现,Element UI里的autosize textarea的初始高度是会随着padding的值变化
所以,我就在浏览器里调整padding的大小 ,直到它撑起来的高度和figma里要求的高度一致
然后把全局样式里的padding改成对应的值
  1. $inputFontSize: 16px;
  2. .el-textarea {
  3.   textarea {
  4.     padding: 7.5px 0 7.5px 8px; // 只要改变这里的 padding 就可以影响到 textarea 的高度
  5.     font-size: $inputFontSize;
  6.     line-height: 21px;
  7.   }
  8. }
复制代码
总结
到此这篇关于如何为 Element UI 里的 autosize textarea 设置高度的文章就介绍到这了,更多相关Element UI autosize textarea 高度内容请搜索中国红客联盟以前的文章或继续浏览下面的相关文章,希望大家以后多多支持中国红客联盟!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

中国红客联盟公众号

联系站长QQ:5520533

admin@chnhonker.com
Copyright © 2001-2025 Discuz Team. Powered by Discuz! X3.5 ( 粤ICP备13060014号 )|天天打卡 本站已运行