11521 sujets

JavaScript, DOM et API Web HTML5

Bonjour, je sollicite votre aide car j'ai du mal à faire apparaitre l'input superficie et le checkbox uniquement lorsque les catégories ayant des superficies sont sélectionnées.
Vous pouvez voir dans la photo 1 que l'input et le checkbox restent présent sans même avoir choisi la catégorie:

upload/1643378791-84026-y6.png


Après avoir choisi une catégorie qui n'a pas de superficie telle qu'on peut voir dans la photo2, moto par exemple, ça laisse un grand espace entre les autres input:

upload/1643378828-84026-y7.png

Objectifs:
1-ça serait bien si seulement lorsqu'on choisit les catégories ayant une superficie, que les 2 champs superficie et colonne apparaissent à ce moment là.
2-Le if dans le code JS pour afficher ou cacher, marche uniquement pour les categories ayant des options value de 501 à 504 (ayant une superficie) et pas pour ceux de 101 à 106(ayant une superficie également). L'objectif est que ça marche également pour ceux là aussi.

Voici le code javascript:
function choisirsup()
{
  var sup= document.getElementById("typecategorie");

 if(sup.value>=101 && sup.value <=106)
  {
    document.getElementById("infosuperficie").style.visibility="visible"; 
}
else{
  document.getElementById("infosuperficie").style.visibility="hidden"; 
}
if(sup.value>=501 && sup.value <=504)
  {
    document.getElementById("infosuperficie").style.visibility="visible"; 
}
else{
  document.getElementById("infosuperficie").style.visibility="hidden"; 
}
}


La partie concernée dans le formulaire:


<span>  <label for="categorieannonce">Catégorie de votre annonce</label></span> <br>
                <select id="typecategorie" onchange="choisirsup()" name="categorie" required>

                <option value="" disabled selected>Catégorie</option>
                	<optgroup label ='Immobilier'> 
<option value='101'>Vente de Maisons</option>
<option value='102'>Location de Maison</option>
//Autre suite de code...


<div id="infosuperficie"
<span><label for= "superficie">Superficie</label></span> <br>
            <input type="number" id="superficie" name="superficie">  <br> <br>

            <span> <label for= "unite">Unité</label></span> <br>
            <input type="checkbox" name="unite[]" value="m2"> m2 <br>
<input type="checkbox" name="unite[]" value="ha">ha
<br> <br> 

</div>
Modérateur
Salut,

1/ Là tu masque juste, donc ils gardent leur place dans le DOM. Tu peux changer le display à none pour les sortir mais je ne sais pas si ca va pas causer des soucis dans ton code. A voir.

2/ si tu refais le chemin de la variable :

On choisi 101
choisirsup() avec 101
sup.value>=101 && sup.value <=106 est TRUE
donc document.getElementById("infosuperficie").style.visibility="visible";
if(sup.value>=501 && sup.value <=504) est FALSE
donc document.getElementById("infosuperficie").style.visibility="hidden";
rien ne s'affiche.

Dans l'autres sens ca marche vu qu'il a le dernier mot.
fait un seul if avec les deux conditions et un OU
Bonjour Laurent, et merci pour ta réponse. Pour la 1 j'ai réussi, mais pour la 2 ça n'a pas marché.

Pour la 1, je suis arrivé. Dans le css, j'ai fait ainsi:
#infosuperficie{
  display:none;
}

Coté javascript:

function choisirsup()
{
  var sup= document.getElementById("typecategorie");

  console.log(sup);
  console.log(sup.value);


  if(sup.value>=101 && sup.value <=106)
  {
    document.getElementById("infosuperficie").style.display="block"; 

}

else{
  document.getElementById("infosuperficie").style.display="none"; 

}


Pour la 2, quand on ajoute 2 condition dans un if ça n'a pas marché:
function choisirsup()
{
  var sup= document.getElementById("typecategorie");

  console.log(sup);
  console.log(sup.value);


  if(sup.value>=101 && sup.value <=106)
  {
    document.getElementById("infosuperficie").style.display="block"; 

}
elseif(sup.value>=501 && sup.value <=504)
{
  document.getElementById("infosuperficie").style.display="block"; 
}
else{
  document.getElementById("infosuperficie").style.display="none"; 

}
}
Modérateur
Alors effectivement tu peux passer pas un else if mais attention y'a un espace :

if (sup.value >= 101 && sup.value <= 106) {
	console.log('ok1');
} else if (sup.value >=501 && sup <= 504) {
	console.log('ok2');
} else {
	console.log('ko');
}


mais je te parlais de faire un truc comme ça :


if( (sup>=101 && sup <=106) || (sup>=501 && sup <=504)) {
	console.log('ok');
} else {
	console.log('ko');
}

Modifié par _laurent (28 Jan 2022 - 23:36)
Meilleure solution