為了提高用戶體驗,我在午休時候想起了是不是可以用jQuery寫個插件。想到不如做到,果然,我實現了這個功能。在寫這個插件時我潛意識裡想到這樣的插件網上應該有人寫過,不過我並沒有去搜索,你有興趣可以找一找。下面是插件的源代碼。
源代碼
代碼如下:
;(function($) {
$.fn.autoSizeText = function(settings) {
var _defaultSettings = {min:20,max:40};
var _settings = $.extend(_defaultSettings, settings);
var _handler = function() {
jQuery(this).keyup(function() {
if (jQuery(this).attr("type") != 'text') {
return false;
}
jQuery(this).attr("size", _settings.min);
var actLength = jQuery(this).val().length;
if (actLength > _settings.min && actLength < _settings.max) {
jQuery(this).attr("size", actLength + 1);
} else if (actLength <= _settings.min) {
jQuery(this).attr("size", _settings.min);
}
});
};
return this.each(_handler);
};
})(jQuery);
調用方法:$(':text').autoSizeText();即可。
本插件有兩個可選參數:max(設置文本框最大的size,超過此值不再size增長,默認值40)和min(設置文本框最小的size,同時也是文本框的初始size,默認值為20),在調用時可以修改。
例如:$(':text').autoSizeText({min:24,max:35});
$(':text').autoSizeText({max:35});//min沒有設置,取默認值20
$(':text').autoSizeText({min:12});//max沒有設置,取默認值40
你可以在此基礎上繼續擴展,例如可以支持textarea。
enjoy it!