Reputation: 15
After several tests, I can not find how to remove my 2 fields INPUT, text and number.
I created 3 fields when I click on my button which has the class "buttonAdd" with createElement, which creates 2 fields INPUT and 1 field IMG "which is the icon for deleted".
Say, how to remove my 2 fields INPUT "objetInputSuivant" and "poidsInputSuivant" when I click on my IMG icon?
I tested with removeChild and with parentElement but I can not do it
I removed my tests to post the code properly
const NewInputCampement = (function() {
let i = 2;
return function NewInputCampement() {
i++;
if (document.getElementById("AddChampCampement").childNodes.length < 39) {
let Objet = document.createElement("INPUT");
let Poids = document.createElement("INPUT");
let Supprimer = document.createElement("IMG");
Supprimer.className = "SupprimerStyle";
Supprimer.src = "assets/img/supprimer.png";
Supprimer.id = "SupprimerCampement_" + i;
Supprimer.alt = "supprimer";
Supprimer.onclick = function() {
SupprimerChamp();
} // for IE
Supprimer.setAttribute('onclick', 'SupprimerChamp();'); // for FF
document.getElementById("AddChampCampement").appendChild(Supprimer);
Objet.type = "text";
Objet.className = "objetInput";
Objet.placeholder = "OBJET";
Objet.id = "textCampement_" + i;
Objet.onkeyup = function() {
this.value = this.value.toUpperCase();
}
Objet.maxLength = 18;
document.getElementById("AddChampCampement").appendChild(Objet);
Poids.type = "number";
Poids.className = "poidsInput";
Poids.placeholder = "POIDS";
Poids.name = "valInputCampement";
Poids.id = "poidsCampement_" + i;
Poids.onkeypress = function() {
return !(event.charCode == 46 || event.charCode == 44 || event.charCode == 188 || event.charCode == 190);
}
Poids.onkeyup = function() {
TotalCalcul();
limit(this);
}
document.getElementById("AddChampCampement").appendChild(Poids);
}
}
})()
<form class="inputBlock">
<input class="objetInput" type="text" maxlength="18" placeholder="OBJET" onkeyup='this.value=this.value.toUpperCase()'>
<input class="poidsInput" type="number" name="valInputCampement" id="poidsCampement_1" onkeyup="TotalCalcul(); limit(this);" placeholder="POIDS" onkeypress="return !(event.charCode == 46 || event.charCode == 44 || event.charCode == 188 || event.charCode == 190)">
<input class="objetInputSuivant" type="text" maxlength="18" placeholder="OBJET" onkeyup='this.value=this.value.toUpperCase()'>
<input class="poidsInputSuivant" type="number" name="valInputCampement" id="poidsCampement_2" onkeyup="TotalCalcul(); limit(this);" placeholder="POIDS" onkeypress="return !(event.charCode == 46 || event.charCode == 44 || event.charCode == 188 || event.charCode == 190)">
<div id="AddChampCampement"></div>
<button class="buttonAdd" type="button" width="295px" height="50px" onclick="NewInputCampement()">AJOUTER UN OBJET</button>
<input class="totalInput" type="number" id="totalCampement" value="0" readonly>
</form>
Upvotes: 0
Views: 67
Reputation: 65806
Say, how to remove my 2 fields INPUT "objetInputSuivant" and "poidsInputSuivant" when I click on my IMG icon?
parentElement.removeChild()
is the correct way:
const NewInputCampement = (function() {
let i = 2;
return function NewInputCampement() {
i++;
if (document.getElementById("AddChampCampement").childNodes.length < 39) {
let Objet = document.createElement("INPUT");
let Poids = document.createElement("INPUT");
let Supprimer = document.createElement("IMG");
Supprimer.className = "SupprimerStyle";
Supprimer.src = "assets/img/supprimer.png";
Supprimer.id = "SupprimerCampement_" + i;
Supprimer.alt = "supprimer";
Supprimer.addEventListener("click", function() {
// Get parent element of elements to be removed
let parent = document.getElementById("AddChampCampement");
// Remove each of the children
parent.removeChild(Objet);
parent.removeChild(Poids);
parent.removeChild(this);
});
document.getElementById("AddChampCampement").appendChild(Supprimer);
Objet.type = "text";
Objet.className = "objetInput";
Objet.placeholder = "OBJET";
Objet.id = "textCampement_" + i;
Objet.onkeyup = function() {
this.value = this.value.toUpperCase();
}
Objet.maxLength = 18;
document.getElementById("AddChampCampement").appendChild(Objet);
Poids.type = "number";
Poids.className = "poidsInput";
Poids.placeholder = "POIDS";
Poids.name = "valInputCampement";
Poids.id = "poidsCampement_" + i;
Poids.onkeypress = function() {
return !(event.charCode == 46 || event.charCode == 44 || event.charCode == 188 || event.charCode == 190);
}
Poids.onkeyup = function() {
TotalCalcul();
limit(this);
}
document.getElementById("AddChampCampement").appendChild(Poids);
}
}
})()
<form class="inputBlock">
<input class="objetInput" type="text" maxlength="18" placeholder="OBJET" onkeyup='this.value=this.value.toUpperCase()'>
<input class="poidsInput" type="number" name="valInputCampement" id="poidsCampement_1" onkeyup="TotalCalcul(); limit(this);" placeholder="POIDS" onkeypress="return !(event.charCode == 46 || event.charCode == 44 || event.charCode == 188 || event.charCode == 190)">
<input class="objetInputSuivant" type="text" maxlength="18" placeholder="OBJET" onkeyup='this.value=this.value.toUpperCase()'>
<input class="poidsInputSuivant" type="number" name="valInputCampement" id="poidsCampement_2" onkeyup="TotalCalcul(); limit(this);" placeholder="POIDS" onkeypress="return !(event.charCode == 46 || event.charCode == 44 || event.charCode == 188 || event.charCode == 190)">
<div id="AddChampCampement"></div>
<button class="buttonAdd" type="button" width="295px" height="50px" onclick="NewInputCampement()">AJOUTER UN OBJET</button>
<input class="totalInput" type="number" id="totalCampement" value="0" readonly>
</form>
And (FYI), for the love of God, stop using inline HTML event handlers, separate your HTML from your JavaScript, and follow modern standards by using .addEventListener()
.
Upvotes: 1