Dynamiczne dodawanie elementów wejściowych do formularza

89

Przeczytałem wiele blogów i postów na temat dynamicznego dodawania zestawów pól, ale wszystkie dają bardzo skomplikowaną odpowiedź. To, czego wymagam, nie jest takie skomplikowane.

Mój kod HTML:

<input type="text" name="member" value="">Number of members: (max. 10)<br />
<a href="#" id="filldetails">Fill Details</a>

Tak więc użytkownik wprowadzi wartość całkowitą (sprawdzam walidację za pomocą javascript) w inputpolu. Po kliknięciu Fill Detailslinku pojawi się odpowiednia liczba pól wejściowych, które może wprowadzić. Chcę to osiągnąć za pomocą javascript.

Nie jestem profesjonalistą w javascript. Zastanawiałem się, jak pobrać liczbę całkowitą wypełnioną przez użytkownika w inputpolu za pośrednictwem linku i wyświetlając odpowiednią liczbę pól wejściowych.

xan
źródło

Odpowiedzi:

149

Możesz użyć onclickmodułu obsługi zdarzeń, aby uzyskać wartość wejściową dla pola tekstowego. Upewnij się, że nadałeś polu unikalny idatrybut, abyś mógł bezpiecznie się do niego odwoływać poprzez document.getElementById():

Jeśli chcesz dynamicznie dodawać elementy, powinieneś mieć pojemnik, w którym je umieścić. Na przykład a <div id="container">. Twórz nowe elementy za pomocą document.createElement()i appendChild()dołączaj każdy z nich do kontenera. Możesz być zainteresowany wyprowadzeniem znaczącego nameatrybutu (np. name="member"+iDla każdego z dynamicznie generowanych <input>plików, jeśli mają być przesłane w formularzu).

Zauważ, że możesz również tworzyć <br/>elementy za pomocą document.createElement('br'). Jeśli chcesz po prostu wypisać jakiś tekst, możesz użyć document.createTextNode()zamiast tego.

Ponadto, jeśli chcesz wyczyścić kontener za każdym razem, gdy ma się zapełnić, możesz użyć hasChildNodes()i removeChild()razem.

<html>
<head>
    <script type='text/javascript'>
        function addFields(){
            // Number of inputs to create
            var number = document.getElementById("member").value;
            // Container <div> where dynamic content will be placed
            var container = document.getElementById("container");
            // Clear previous contents of the container
            while (container.hasChildNodes()) {
                container.removeChild(container.lastChild);
            }
            for (i=0;i<number;i++){
                // Append a node with a random text
                container.appendChild(document.createTextNode("Member " + (i+1)));
                // Create an <input> element, set its type and name attributes
                var input = document.createElement("input");
                input.type = "text";
                input.name = "member" + i;
                container.appendChild(input);
                // Append a line break 
                container.appendChild(document.createElement("br"));
            }
        }
    </script>
</head>
<body>
    <input type="text" id="member" name="member" value="">Number of members: (max. 10)<br />
    <a href="#" id="filldetails" onclick="addFields()">Fill Details</a>
    <div id="container"/>
</body>
</html>

Zobacz próbkę roboczą w tym JSFiddle .

Xavi López
źródło
Postępowałem zgodnie z twoją radą. Ale kiedy klikam, konsola przeglądarki wyświetla ten błąd:Uncaught TypeError: Cannot call method 'appendChild' of undefined
xan
Odpowiedź bardzo pomocna. I jak mogę dodać klasę CSS do pola
Pravinraj Venkatachalam
3
@Pravin Cieszę się, że to pomogło, zobacz Jak dodać klasę do danego elementu? . Zasadniczo używajinput.className += ' someCSSClass';
Xavi López
1
Kiedy wysyłam formularz, nowe pola generowane dynamicznie nie są przesyłane, tak jak inne pola, które były częścią oryginalnego HTML. Pojawiają się wizualnie i mogę je obejrzeć, ale się nie poddają. Jakieś pomysły, dlaczego tak się stało?
circle1
@ circle1 Upewnij się, że dynamicznie generowane elementy mają unikalny nameatrybut. Tylko elementy formularza z atrybutem nazwy będą miały przekazane wartości podczas przesyłania formularza.
Xavi López
29

Wypróbuj ten kod JQuery, aby dynamicznie dołączać formularz, pole i zachowanie usuwania / usuwania:

$(document).ready(function() {
    var max_fields = 10;
    var wrapper = $(".container1");
    var add_button = $(".add_form_field");

    var x = 1;
    $(add_button).click(function(e) {
        e.preventDefault();
        if (x < max_fields) {
            x++;
            $(wrapper).append('<div><input type="text" name="mytext[]"/><a href="#" class="delete">Delete</a></div>'); //add input box
        } else {
            alert('You Reached the limits')
        }
    });

    $(wrapper).on("click", ".delete", function(e) {
        e.preventDefault();
        $(this).parent('div').remove();
        x--;
    })
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="container1">
    <button class="add_form_field">Add New Field &nbsp; 
      <span style="font-size:16px; font-weight:bold;">+ </span>
    </button>
    <div><input type="text" name="mytext[]"></div>
</div>

Zapoznaj się z demo tutaj

M. Lak
źródło
Może robię coś nie tak, ale w moim przypadku każde naciśnięcie klawisza Enter w polu tekstowym w tym formularzu spowoduje uruchomienie funkcji przycisku
``
1
<button type="button" ...>i problem został rozwiązany.
Maxi Mus