快捷搜索:   nginx

jquery实现自动增长的文本输入框

  昨天在与业务人员沟通时,遇到这样一种需求:文本输入框内的字数不能确定,而input type="text"的size是固定的,当字数超过size时(默认是20),先输入的内容就会从文本框的左端隐藏起来,不便于输入。       为了提高用户体验,我在午休时候想起了是不是可以用jQuery写个插件。想到不如做到,果然,我实现了这个功能。在写这个插件时我潜意识里想到这样的插件网上应该有人写过,不过我并没有去搜索,你有兴趣可以找一找。下面是插件的源代码。   
  1. ;(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!
顶(1)
踩(0)

您可能还会对下面的文章感兴趣:

最新评论