textarea高度自适应

方法一:div模拟textarea文本域轻松实现高度自适应

demo演示地址:http://www.xuanfengge.com/demo/201308/textarea/demo1.html

因为textarea不支持自适应高度,就是定好高度或者是行数之后,超出部分就会显示滚动条,看起来不美观。

而用DIV来模拟时,首先遇到的问题是:div怎么实现输入功能?

可能我们还是第一次见到这个属性contenteditable,如一个普通的block元素上加个contenteditable="true"就实现编辑,出现光标了。如

contenteditable属性虽是HTML5里面的内容,但是IE似乎老早就支持此标签属性了。所以,兼容性方面还是不用太担心的。

CSS代码

 HTML代码

CSS代码中,因为IE6不支持min/max,所以做了hack,其他的也好理解。

方法二:文本框textarea根据输入内容自适应高度

demo演示地址:http://www.xuanfengge.com/demo/201308/textarea/demo2.html

这个写法是用原生JS写的,考虑了很多兼容性问题,完全和新浪微博的回复效果一样的功能。有兴趣的童鞋可以仔细分析下代码。

CSS代码

javascript代码

HTML代码(写在body里面的)

<textarea id="textarea" placeholder="回复内容"></textarea> <script> var text = document.getElementById("textarea"); autoTextarea(text);// 调用 </script>
1
2
3
4
5
< textarea id = "textarea" placeholder = "回复内容" > < / textarea >
     <script>
         var text = document . getElementById ( "textarea" ) ;
         autoTextarea ( text ) ; // 调用
     </script>

转载自:https://blog.csdn.net/littlebirdofjava/article/details/14166391






猜你喜欢

转载自blog.csdn.net/qq736150416/article/details/80324971