效果图及代码如下:<script src="../Scripts/jquery-1.4.1.js" type="text/javascript"></script><script src="jquery.autotab.js" type="text/javascript"></script><script type="text/javascript">$(document).ready(function() { $('#example_form').submit(function() { return false; });
// Number example $('#area_code').autotab({ target: 'number1', format: 'numeric' }); $('#number1').autotab({ target: 'number2', format: 'numeric', previous: 'area_code' }); $('#number2').autotab({ target: 'ssn1', previous: 'number1', format: 'numeric' });
$('#ssn1').autotab({ target: 'ssn2', format: 'numeric', previous: 'number2' }); $('#ssn2').autotab({ target: 'ssn3', format: 'numeric', previous: 'ssn1' }); $('#ssn3').autotab({ target: 'text1', format: 'numeric', previous: 'ssn2' });
// Text example $('#text1').autotab({ target: 'text2', format: 'text', previous: 'ssn3' }); $('#text2').autotab({ target: 'text3', format: 'text', previous: 'text1' }); $('#text3').autotab({ target: 'alpha1', format: 'text', previous: 'text2' });
// Alpha example $('#alpha1').autotab({ target: 'alpha2', format: 'alpha', previous: 'text3' }); $('#alpha2').autotab({ target: 'alpha3', format: 'alpha', previous: 'alpha1' }); $('#alpha3').autotab({ target: 'alpha4', format: 'alpha', previous: 'alpha2' }); $('#alpha4').autotab({ target: 'alpha5', format: 'alpha', previous: 'alpha3' }); $('#alpha5').autotab({ target: 'alphanumeric1', previous: 'alpha4', format: 'alpha' });
// Alphanumeric example $('#alphanumeric1').autotab({ target: 'alphanumeric2', format: 'alphanumeric', uppercase: true, previous: 'alpha5' }); $('#alphanumeric2').autotab({ target: 'alphanumeric3', format: 'alphanumeric', uppercase: true, previous: 'alphanumeric1' }); $('#alphanumeric3').autotab({ target: 'alphanumeric4', format: 'alphanumeric', uppercase: true, previous: 'alphanumeric2' }); $('#alphanumeric4').autotab({ target: 'alphanumeric5', format: 'alphanumeric', uppercase: true, previous: 'alphanumeric3' }); $('#alphanumeric5').autotab({ target: 'all1', previous: 'alphanumeric4', format: 'alphanumeric', uppercase: true });
// All example $('#all1').autotab({ target: 'all2', previous: 'alphanumeric5' }); $('#all2').autotab({ target: 'all3', previous: 'all1' }); $('#all3').autotab({ target: 'all4', previous: 'all2' }); $('#all4').autotab({ target: 'all5', previous: 'all3' }); $('#all5').autotab({ previous: 'all4' });});</script>
<h3>jQuery plugin --- Autotab--自动切换文本框。</h3><form action="" method="post" id="example_form"><div><strong>Phone Number:</strong></div><input type="text" name="area_code" id="area_code" maxlength="3" size="3" /> -<input type="text" name="number1" id="number1" maxlength="3" size="3" /> -<input type="text" name="number2" id="number2" maxlength="4" size="5" />
<div><strong>Social Security Number:</strong></div><input type="text" name="ssn1" id="ssn1" maxlength="3" size="3" /> -<input type="text" name="ssn2" id="ssn2" maxlength="2" size="3" /> -<input type="text" name="ssn3" id="ssn3" maxlength="4" size="5" />
<div><strong>Text characters only:</strong></div><input type="text" name="text1" id="text1" maxlength="5" size="4" /> -<input type="text" name="text2" id="text2" maxlength="4" size="4" /> -<input type="text" name="text3" id="text3" maxlength="5" size="4" />
<div><strong>Alpha only:</strong></div><input type="text" name="alpha1" id="alpha1" maxlength="5" size="4" /> -<input type="text" name="alpha2" id="alpha2" maxlength="5" size="4" /> -<input type="text" name="alpha3" id="alpha3" maxlength="5" size="4" /> -<input type="text" name="alpha4" id="alpha4" maxlength="5" size="4" /> -<input type="text" name="alpha5" id="alpha5" maxlength="5" size="4" />
<div><strong>Uppercase letters and numbers (Converts lowercase letters to uppercase):</strong></div><input type="text" name="alphanumeric1" id="alphanumeric1" maxlength="5" size="4" /> -<input type="text" name="alphanumeric2" id="alphanumeric2" maxlength="5" size="4" /> -<input type="text" name="alphanumeric3" id="alphanumeric3" maxlength="5" size="4" /> -<input type="text" name="alphanumeric4" id="alphanumeric4" maxlength="5" size="4" /> -<input type="text" name="alphanumeric5" id="alphanumeric5" maxlength="5" size="4" />
<div><strong>Any and all characters:</strong></div><input type="text" name="all1" id="all1" maxlength="5" size="4" /> -<input type="text" name="all2" id="all2" maxlength="5" size="4" /> -<input type="text" name="all3" id="all3" maxlength="5" size="4" /> -<input type="text" name="all4" id="all4" maxlength="5" size="4" /> -<input type="text" name="all5" id="all5" maxlength="5" size="4" /></form>
jquery.autotab.js:/* * Autotab - jQuery plugin 1.0 * http://dev.lousyllama.com/auto-tab * * Copyright (c) 2008 Matthew Miller * * Dual licensed under the MIT and GPL licenses: * http://www.opensource.org/licenses/mit-license.php * http://www.gnu.org/licenses/gpl.html * * Revised: 2008/05/22 01:23:25 */
(function($) {
$.fn.autotab = function(options) { var defaults = { format: 'all', // text, numeric, alphanumeric, all maxlength: 2147483647, // Defaults to maxlength value uppercase: false, // Converts a string to UPPERCASE lowercase: false, // Converts a string to lowecase nospace: false, // Remove spaces in the user input target: null, // Where to auto tab to previous: null // Backwards auto tab when all data is backspaced };
$.extend(defaults, options);
var check_element = function(name) { var val = null; var check_id = $('#' + name)[0]; var check_name = $('input[name=' + name + ']')[0];
if(check_id != undefined) val = $(check_id); else if(check_name != undefined) val = $(check_name);
return val; };
var key = function(e) { if(!e) e = window.event;
return e.keyCode; };
// Sets targets to element based on the name or ID passed if(typeof defaults.target == 'string') defaults.target = check_element(defaults.target);
if(typeof defaults.previous == 'string') defaults.previous = check_element(defaults.previous);
var maxlength = $(this).attr('maxlength');
// Each text field has a maximum character limit of 2147483647
// defaults.maxlength has not changed and maxlength was specified if(defaults.maxlength == 2147483647 && maxlength != 2147483647) defaults.maxlength = maxlength; // defaults.maxlength overrides maxlength else if(defaults.maxlength > 0) $(this).attr('maxlength', defaults.maxlength) // defaults.maxlength and maxlength have not been specified // A target cannot be used since there is no defined maxlength else defaults.target = null;
// IE does not recognize the backspace key // with keypress in a blank input box if($.browser.msie) { this.keydown(function(e) { if(key(e) == 8) { var val = this.value;
if(val.length == 0 && defaults.previous) defaults.previous.focus(); } }); }
return this.keypress(function(e) { if(key(e) == 8) { var val = this.value;
if(val.length == 0 && defaults.previous) defaults.previous.focus(); } }).keyup(function(e) { var val = this.value;
switch(defaults.format) { case 'text': var pattern = new RegExp('[0-9]+', 'g'); var val = val.replace(pattern, ''); break;
case 'alpha': var pattern = new RegExp('[^a-zA-Z]+', 'g'); var val = val.replace(pattern, ''); break;
case 'number': case 'numeric': var pattern = new RegExp('[^0-9]+', 'g'); var val = val.replace(pattern, ''); break;
case 'alphanumeric': var pattern = new RegExp('[^0-9a-zA-Z]+', 'g'); var val = val.replace(pattern, ''); break;
case 'all': default: break; }
if(defaults.nospace) { pattern = new RegExp('[ ]+', 'g'); val = val.replace(pattern, ''); }
if(defaults.uppercase) val = val.toUpperCase();
if(defaults.lowercase) val = val.toLowerCase();
this.value = val;
/** * Do not auto tab when the following keys are pressed * 8: Backspace * 9: Tab * 16: Shift * 17: Ctrl * 18: Alt * 19: Pause Break * 20: Caps Lock * 27: Esc * 33: Page Up * 34: Page Down * 35: End * 36: Home * 37: Left Arrow * 38: Up Arrow * 39: Right Arrow * 40: Down Arroww * 45: Insert * 46: Delete * 144: Num Lock * 145: Scroll Lock */ var keys = [8, 9, 16, 17, 18, 19, 20, 27, 33, 34, 35, 36, 37, 38, 39, 40, 45, 46, 144, 145]; var string = keys.toString();
if(string.indexOf(key(e)) == -1 && val.length == defaults.maxlength && defaults.target) defaults.target.focus(); });};
})(jQuery);