jQuery 自动增长的文本输入框实现代码 - Web前端
作者:98wpeu发布时间:2026-05-24分类:网页前端技术浏览:8
导读:为了提高用户体验,我在午休时候想起了是不是可以用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') {
returnfalse;
}
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!
源代码
复制代码 代码如下:
;(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') {
returnfalse;
}
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 滑入滑出效果实现代码 - Web前端
- 下一篇:已经是最后一篇了
相关推荐
- Jquery 滑入滑出效果实现代码 - Web前端
- jQuery div层的放大与缩小简单实现代码 - Web前端
- 基于jquery的tab切换 js原理 - Web前端
- ASP.NET jQuery 实例14 在ASP.NET form中校验时间范围 - Web前端
- jQuery异步验证用户名是否存在示例代码 - Web前端
- jQuery在iframe中无法弹出对话框的解决方法 - Web前端
- jQuery的css()方法用法实例 - Web前端
- HTML5中的FileReader、拖拽和canvas教程 - Web前端
- JQuery 1.4 中的Ajax问题 - Web前端
- JQuery拖动表头边框线调整表格列宽效果代码 - Web前端
- 网页前端技术排行
- 最近发表
-
- WordPress随机显示特色图片插件:Random Post Thumbnails
- KeePass实现Chrome浏览器自动填充密码方法一
- LNMP一键包nginx 301强制跳转到https教程
- KeePass实现Chrome浏览器自动填充密码方法二
- #建站# 免费的VPS管理软件Xshell8/Xftp8中文版下载
- 使用Xshell 8连接VPS教程_电脑登录vps的方法
- WordPress评论界面添加烟花????效果
- 不同浏览器书签同步方案:坚果云+Floccus_详细使用教程
- iOS端KeePassXC客户端APP:Strongbox Password Safe
- 给WordPress评论中的Gravatar头像图片添加ALT属性


