为了提高用户体验,我在午休时候想起了是不是可以用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!
推荐阅读
用jQuery简化Ajax开发实现方法第1/2页
一些简单的代码简化 下面是一个简单示例,它说明了 jQuery 对代码的影响。要执行一些真正简单和常见的任务,比方说为页面的某一区域中的每个链接附加一个单击(click)事件,您可以使用纯 JavaScript 代码和 DOM 脚>>>详细阅读
本文标题:jQuery 自动增长的文本输入框实现代码
地址:http://www.17bianji.com/kaifa2/JS/26664.html
1/2 1