Я пытаюсь создать ввод серийного номера из 4 частей, который автоматически продвигается для каждой части серийного номера.

Например 1-384-3884-39

Кроме того, как мне добавить строки в одну строку при отправке?

1
Kirk Ross 12 Авг 2014 в 22:59

3 ответа

Лучший ответ

Я делаю для вас скрипку http://jsfiddle.net/fLz4LL9g/3/

Форма:

<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();
        }
});
3
rnrneverdies 12 Авг 2014 в 19:51

Если я вас правильно понимаю, я думаю, вы могли бы использовать эту функцию:

Рабочая демонстрация: http://jsfiddle.net/kfbjy8fr/1/

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();

    }
}
1
bencripps 12 Авг 2014 в 19:34

Я нашел плагин ... но все же хотел бы узнать, как это сделать проще всего.

http://www.jqueryscript.net/form/jQuery-Plugin-For-Auto-Tab-Form-Fields-autotab.html

1
Kirk Ross 12 Авг 2014 в 19:12