手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >jQuery 自动增长的文本输入框实现代码
jQuery 自动增长的文本输入框实现代码
摘要:为了提高用户体验,我在午休时候想起了是不是可以用jQuery写个插件。想到不如做到,果然,我实现了这个功能。在写这个插件时我潜意识里想到这样...

为了提高用户体验,我在午休时候想起了是不是可以用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 自动增长的文本输入框实现代码】相关文章:

显示行号的文本输入框

Js和JQuery获取鼠标指针坐标的实现代码分享

Jquery动态添加输入框的方法

jQuery实现自动滚动到页面顶端的方法

javascript实现淡蓝色的鼠标拖动选择框实例

jquery插件validation实现验证身份证号等

自动检查并替换文本框内的字符

jQuery结合ajax实现动态加载文本内容

原生JS和JQuery动态添加、删除表格行的方法

jQuery解析XML文件同时动态增加js文件的方法

精品推荐
分类导航