Jquery 自动推进输入字段(多部件序列号)
我正在尝试构建一个由4部分组成的序列号输入,它会自动为序列号的每一部分前进 e、 g.1-384-3884-39Jquery 自动推进输入字段(多部件序列号),jquery,forms,input,Jquery,Forms,Input,我正在尝试构建一个由4部分组成的序列号输入,它会自动为序列号的每一部分前进 e、 g.1-384-3884-39 另外,我如何在提交时将这些字符串添加到一个字符串中?我发现了一个插件。。。但我仍然想学习最简单的方法来做到这一点 我找到了一个插件。。。但我仍然想学习最简单的方法来做到这一点 如果我理解正确,我认为您可以使用此功能: 工作演示: 如果我理解正确,我认为您可以使用此功能: 工作演示: 我帮你拉小提琴 表格: - - - 代码: var-digitsPerBox=4; ///每个输入
另外,我如何在提交时将这些字符串添加到一个字符串中?我发现了一个插件。。。但我仍然想学习最简单的方法来做到这一点
我找到了一个插件。。。但我仍然想学习最简单的方法来做到这一点
如果我理解正确,我认为您可以使用此功能: 工作演示:
如果我理解正确,我认为您可以使用此功能: 工作演示: 我帮你拉小提琴 表格:
-
-
-
代码:
var-digitsPerBox=4;
///每个输入
$(“.i”)。关于(“输入”,函数(e){
if(e.target.value.length==digitsPerBox){
var t=$(即目标);
如果(t.attr(“id”)=“i4”){
///在此提交
var txt=$(“#i1”).val()+“-”+$(“#i2”).val()+“-”+$(“#i3”).val()+“-”+$(“#i4”).val();
警报(txt);
}否则{
///自动对焦下一个框
t、 next().focus();
}
}
///每框限位
if(e.target.value.length>digitsPerBox){
e、 target.value=e.target.value.substr(0,数字框);
}
/////只允许数量
}).keydown(功能(e){
//允许:退格、删除、制表符、转义、输入和。
如果($.inArray(例如,keyCode[46,8,9,27,13,110,190])!=-1||
//允许:Ctrl+A
(e.keyCode==65&&e.ctrlKey==true)|
//允许:起始、结束、左、右
我为你拉小提琴
表格:
-
-
-
代码:
var-digitsPerBox=4;
///每个输入
$(“.i”)。关于(“输入”,函数(e){
if(e.target.value.length==digitsPerBox){
var t=$(即目标);
如果(t.attr(“id”)=“i4”){
///在此提交
var txt=$(“#i1”).val()+“-”+$(“#i2”).val()+“-”+$(“#i3”).val()+“-”+$(“#i4”).val();
警报(txt);
}否则{
///自动对焦下一个框
t、 next().focus();
}
}
///每框限位
if(e.target.value.length>digitsPerBox){
e、 target.value=e.target.value.substr(0,数字框);
}
/////只允许数量
}).keydown(功能(e){
//允许:退格、删除、制表符、转义、输入和。
如果($.inArray(例如,keyCode[46,8,9,27,13,110,190])!=-1||
//允许:Ctrl+A
(e.keyCode==65&&e.ctrlKey==true)|
//允许:起始、结束、左、右
(e.keyCode>=35&&e.keyCode
function getResult() {
var HTMLinsert = "",
values = $(document).find('input');
$.each( values, function( index, element) {
HTMLinsert += element.value
if (index !== values.length -1 ) {
HTMLinsert += '-'
}
})
return HTMLinsert;
}
var checkForTab = function() {
if ( $(this).prop('maxlength') === $(this).val().length ) {
$(this).closest('input').next().focus();
}
}
<form>
<input id="i1" class="i" type="number" value="">-
<input id="i2" class="i" type="number">-
<input id="i3" class="i" type="number">-
<input id="i4" class="i" type="number">
</form>
var digitsPerBox = 4;
/// EACH INPUT
$(".i").on("input",function(e) {
if (e.target.value.length == digitsPerBox) {
var t = $( e.target );
if (t.attr("id") == "i4") {
/// SUBMIT HERE
var txt = $("#i1").val() + "-" + $("#i2").val() + "-" + $("#i3").val() + "-" + $("#i4").val();
alert(txt);
} else {
/// AUTO FOCUS NEXT BOX
t.next().focus();
}
}
/// LIMIT DIGITS PER BOX
if (e.target.value.length > digitsPerBox) {
e.target.value = e.target.value.substr(0,digitsPerBox);
}
///// ONLY NUMBER ALLOWED
}).keydown(function (e) {
// Allow: backspace, delete, tab, escape, enter and .
if ($.inArray(e.keyCode, [46, 8, 9, 27, 13, 110, 190]) !== -1 ||
// Allow: Ctrl+A
(e.keyCode == 65 && e.ctrlKey === true) ||
// Allow: home, end, left, right
(e.keyCode >= 35 && e.keyCode <= 39)) {
// let it happen, don't do anything
return;
}
// Ensure that it is a number and stop the keypress
if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
e.preventDefault();
}
});