IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

Récupérer et comparer les valeurs saisies dans deux INPUT


Sujet :

JavaScript

  1. #1
    Membre habitué
    Homme Profil pro
    Enseignant
    Inscrit en
    Octobre 2005
    Messages
    246
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Mali

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2005
    Messages : 246
    Points : 159
    Points
    159
    Par défaut Récupérer et comparer les valeurs saisies dans deux INPUT
    Bonjour tout le monde,

    Je dois saisir dans un formulaire deux valeurs d'un intervalle. Je voulais faire un test de comparaison des deux valeurs afin de contrôler si la valeur de la borne supérieure de l'intervalle n'est pas inférieure à celle de la borne inférieure et afficher un message.
    Après avoir fait des recherches, j'ai fait ce-ci :
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="ISO-8859-1">
    <title>Gestion</title>
    <script type="text/javascript" src="ordeP.js"></script>
    <script src="js/ajax.js" type="text/javascript"></script>
    <link rel="stylesheet" media="screen" type="text/css" href="style.css" />
    </head>
    <body>
    .........
    <td><input type="text" name="borneinf" id="borneinf" size="20" placeholder="borne inférieure" /></td>
    <td><input type="text" name="bornesup" id="borneinf" size="20" placeholder="borne supérieure" /></td>
    ...................
    <p id="answer"></p>
    .................
     
    <%@ include file="/WEB-INF/piedpage.jsp"%>
    <script>
    //ajout du 26/07/2019
            var valeur1=document.getElementById("borneinf");
            var valeur2=document.getElementById("bornesup");
            valeur2.addEventListener("input", verifier_valeur);
            function verifier_valeurs(){
                    var v1=parseFloat(valeur1.value);
                    var v2=parseFloat(valeur2.value);
                    if(v2<=v1) 
                             document.getElementById("answer").innerHTML="La borne supérieure doit être plus grande que la borne inférieure !";
    }
    </script>
    </body>
    </html>

    Le message ne s'affiche pas après la saisie des valeurs dans les deux INPUT.

    Guidez moi, s'il vous plait.

  2. #2
    Expert éminent sénior
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 097
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 097
    Points : 16 606
    Points
    16 606
    Par défaut
    Salut
    <td><input type="text" name="bornesup" id="borneinf" size="20" placeholder="borne supérieure" /></td> l'id n'est pas bon
    <td><input type="text" name="bornesup" id="bornesup" size="20" placeholder="borne supérieure" /></td> là c'est mieux

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
            valeur2.addEventListener("input", verifier_valeur);
            function verifier_valeurs(){// <***********  le s du nom de la fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
            valeur2.addEventListener("input", verifier_valeurs);// <********** là c'est mieux
            function verifier_valeurs(){

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    On peut ici utiliser des <input type="number" />.
    On peut :
    • régler le pas (step) en fonction du nombre de décimale voulu
    • définir des valeurs min et max


    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <input type="number" name="borneinf" id="borneinf" size="20" placeholder="borne inférieure" step="0.01" min="" max="" />
    <input type="number" name="bornesup" id="bornesup" size="20" placeholder="borne supérieure" step="0.01" min="" max="" />
    <p id="answer"></p>
    Il faut aussi activer la fonction sur la borne inf, qui peut être remplie ou modifiée APRES la borne sup.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    "use strict";
    const valeur1 = document.getElementById("borneinf");
    const valeur2 = document.getElementById("bornesup");
    const answer = document.getElementById("answer");
    valeur1.addEventListener("input", verif_infsup);
    valeur2.addEventListener("input", verif_infsup);
     
    function verif_infsup()
    {
      let v1 = parseFloat(valeur1.value);
      let v2 = parseFloat(valeur2.value);
      answer.innerHTML = (v1!='' && v2!='' && v2<=v1)? "La borne supérieure doit être plus grande que la borne inférieure" : "";    
    }
    Dernière modification par ProgElecT ; 27/07/2019 à 12h10.

  4. #4
    Membre habitué
    Homme Profil pro
    Enseignant
    Inscrit en
    Octobre 2005
    Messages
    246
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Mali

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2005
    Messages : 246
    Points : 159
    Points
    159
    Par défaut
    Merci à vous.

    Je testerai votre proposition, car entre temps, j'avais eu une solution en passant par onClick() sur un bouton.
    Est ce nécessaire encore de la mettre ici ?

  5. #5
    Membre habitué
    Homme Profil pro
    Enseignant
    Inscrit en
    Octobre 2005
    Messages
    246
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Mali

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2005
    Messages : 246
    Points : 159
    Points
    159
    Par défaut
    Ma solution trouvée :

    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <td><input type="text" name="borneinf" id="borneinf" size="20" placeholder="borne inférieure" /></td>
    <td><input type="text" name="bornesup" id="bornesup" size="20" placeholder="borne supérieure" /></td>
     
    <td align="center" colspan="2">
    <input type="button" name= "listerStats1" id="listerStats1" value="Stats Intervalles Superficies" 
    onclick ="check();"/>
    </td>
    JS :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <script>
    		//ajout du 26/07/2019
    	function check(){
    		var v2=parseFloat(document.getElementById("bornesup").value);
    		var v1=parseFloat(document.getElementById("borneinf").value);
    		if(v2<=v1) alert("La borne supérieure doit être plus grande que la borne inférieure !");
    		else {
    			window.location.href='StatsParcellesIntervalesSurface?param1=' + document.getElementById("idlot").value +
    			'&param2=' + document.getElementById("borneinf").value + '&param3='+ document.getElementById("bornesup").value +
    			'&param4=' + document.getElementById("positionparcelle").value + '&param5=' + document.getElementById("refusage").value;
    		}
    			 //document.getElementById("answer").innerHTML="La borne supérieure doit être plus grande que la borne inférieure !";
    	}
    </script>

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 0
    Dernier message: 01/03/2018, 22h55
  2. Réponses: 4
    Dernier message: 12/06/2016, 15h44
  3. Réponses: 1
    Dernier message: 07/03/2015, 06h52
  4. Réponses: 3
    Dernier message: 25/09/2008, 10h26
  5. Réponses: 2
    Dernier message: 08/01/2007, 09h01

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo