代码改变世界

文本框自动撑高JQ插件

2011-10-11 15:49  ☆冷枫☆  阅读(717)  评论(0编辑  收藏  举报
(function($){
$.fn.autoTextarea = function(options) {
var defaults={
maxHeight:null,//文本框是否自动撑高,默认:null,不自动撑高;如果自动撑高必须输入数值,该值作为文本框自动撑高的最大高度
minHeight:$(this).height() //默认最小高度,也就是文本框最初的高度,当内容高度小于这个高度的时候,文本以这个高度显示
};
var opts = $.extend({},defaults,options);
return $(this).each(function() {
$(this).bind("paste cut keydown keyup focus blur",function(){
var height,style=this.style;
this.style.height =  opts.minHeight + 'px';
if(this.scrollHeight > opts.minHeight) {
if(opts.maxHeight && this.scrollHeight > opts.maxHeight) {
height = opts.maxHeight;
style.overflowY = 'scroll';
}else {
height = this.scrollHeight;
style.overflowY = 'hidden';
}
style.height = height  + 'px';
}
});
});
};
})(jQuery);

 

当输入的文字行高度超过文本框本身高度时,文本框便自动改变

$(function(){ 
   $(".chackTextarea-area").autoTextarea({maxHeight:220});
});