jQuery 自動增長的文本輸入框?qū)崿F(xiàn)代碼
更新時間:2010年04月02日 22:23:25 作者:
文本輸入框內(nèi)的字數(shù)不能確定,而input type="text"的size是固定的,當(dāng)字數(shù)超過size時(默認是20),先輸入的內(nèi)容就會從文本框的左端隱藏起來,不便于輸入。
為了提高用戶體驗,我在午休時候想起了是不是可以用jQuery寫個插件。想到不如做到,果然,我實現(xiàn)了這個功能。在寫這個插件時我潛意識里想到這樣的插件網(wǎng)上應(yīng)該有人寫過,不過我并沒有去搜索,你有興趣可以找一找。下面是插件的源代碼。
源代碼
;(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);
調(diào)用方法:$(':text').autoSizeText();即可。
本插件有兩個可選參數(shù):max(設(shè)置文本框最大的size,超過此值不再size增長,默認值40)和min(設(shè)置文本框最小的size,同時也是文本框的初始size,默認值為20),在調(diào)用時可以修改。
例如:$(':text').autoSizeText({min:24,max:35});
$(':text').autoSizeText({max:35});//min沒有設(shè)置,取默認值20
$(':text').autoSizeText({min:12});//max沒有設(shè)置,取默認值40
你可以在此基礎(chǔ)上繼續(xù)擴展,例如可以支持textarea。
enjoy it!
源代碼
復(fù)制代碼 代碼如下:
;(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);
調(diào)用方法:$(':text').autoSizeText();即可。
本插件有兩個可選參數(shù):max(設(shè)置文本框最大的size,超過此值不再size增長,默認值40)和min(設(shè)置文本框最小的size,同時也是文本框的初始size,默認值為20),在調(diào)用時可以修改。
例如:$(':text').autoSizeText({min:24,max:35});
$(':text').autoSizeText({max:35});//min沒有設(shè)置,取默認值20
$(':text').autoSizeText({min:12});//max沒有設(shè)置,取默認值40
你可以在此基礎(chǔ)上繼續(xù)擴展,例如可以支持textarea。
enjoy it!
您可能感興趣的文章:
- 詳解jQuery UI庫中文本輸入自動補全功能的用法
- jQuery實現(xiàn)文本框郵箱輸入自動補全效果
- jquery 實現(xiàn)輸入郵箱時自動補全下拉提示功能
- jquery.fastLiveFilter.js實現(xiàn)輸入自動過濾的方法
- PHP結(jié)合jQuery.autocomplete插件實現(xiàn)輸入自動完成提示的功能
- jQuery實現(xiàn)感應(yīng)鼠標(biāo)動畫效果自動伸長的輸入框?qū)嵗?/a>
- 基于jQuery的input輸入框下拉提示層(自動郵箱后綴名)
- 基于jquery實現(xiàn)的類似百度搜索的輸入框自動完成功能
- 基于jQuery的輸入框無值自動顯示指定數(shù)據(jù)的實現(xiàn)代碼
- jquery判斷字符輸入個數(shù)(數(shù)字英文長度記為1,中文記為2,超過長度自動截?。?/a>
- jQuery實現(xiàn)自動輸入email、時間和域名的方法
相關(guān)文章
jquery判斷checkbox是否選中及改變checkbox狀態(tài)的實現(xiàn)方法
下面小編就為大家?guī)硪黄猨query判斷checkbox是否選中及改變checkbox狀態(tài)的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05jQuery計算textarea中文字數(shù)(剩余個數(shù))的小程序
這篇文章主要介紹了jQuery計算textarea中文字數(shù)(剩余個數(shù))的示例程序,大家參考使用吧2013-11-11jQuery easyui的validatebox校驗規(guī)則擴展及easyui校驗框validatebox用法
這篇文章主要介紹了jQuery easyui的validatebox校驗規(guī)則擴展及easyui校驗框validatebox用法的相關(guān)資料,需要的朋友可以參考下2016-01-01jquery中dom操作和事件的實例學(xué)習(xí)-表單驗證
這個demo的效果是實現(xiàn)用戶輸入時提供實時提醒,并不一定要等到元素失去焦點時才提醒2011-11-11讓網(wǎng)頁跳轉(zhuǎn)到指定位置的jquery代碼非書簽
網(wǎng)頁跳轉(zhuǎn)到指定位置,實現(xiàn)的方法有很多,本文采用最為簡單的一種,喜歡朋友可以學(xué)習(xí)下2013-09-09