前些日子有过textarea高度自适应的需求,找到一个插件flexText,
虽然没有用上去,但是的精简的代码很吸引我。
它是原理是这样的,HTML结构如下:
<div class="expandingArea ">
<pre><span></span><br></pre>
<textarea placeholder="输入文字"></textarea>
</div>
其中的expandingArea的样式仅有
.expandingArea{
position:relative;
}
目的是用于textarea相对于expandingArea绝对定位:
textarea{
position:absolute;
top:0;
left:0;
height:100%;
}
通过这样的样式设置,textArea的高度会始终等于expandingArea的高度,要让textarea的高度变化也只需要调整
expadingArea的高度即可。那么怎么样让expandingArea的高度变化随内容高度变化而变化呢?pre是比较重要的
东西。
pre{
display:block;
visibility:hidden;
}
pre以块形式存在,并且不可见,但是是占用空间的,不像display:none;什么空间也不占。这时需要把textarea中的内容实实的同时到pre里的span标签中,因为pre没有postion:absolute
所以它的高度会一直影响expandingArea的高度。总结原理就是:pre会随内容的高度变化而变化,expandingArea的高度又随pre变化,因为textarea的高度100%textarea的高度会随expandingArea变化,只要同步textarea的内容到pre中,就达到一个textarea随内容高度变化的目的了。
关于这个方法的兼容性问题 在这个方法的创始人博客有提到NEIL JENKINS。个人觉得这个方法是牛逼的,没有通过计算,逻辑上它像上思维推导,代码实现不复杂,轻松愉快。在这个例子中又看到了一次合理的结构可以简化代码的案例:)。