Précédent   Forum des professionnels en informatique > Webmasters - Développement Web > JavaScript
JavaScript Forum programmation JavaScript. Lire : Cours JavaScript, FAQ JavaScript, Toutes les FAQ JavaScript et Sources JavaScript
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 19/01/2011, 09h31   #1
Nouveau Membre du Club
 
Développeur Web
Inscription : juin 2007
Messages : 77
Détails du profil
Informations personnelles :
Âge : 27

Informations professionnelles :
Activité : Développeur Web

Informations forums :
Inscription : juin 2007
Messages : 77
Points : 26
Points : 26
Par défaut Limite de saisie

Bonjour a tous,

Je veut limiter la nombre de caractère saisie dans un <textarea> a 500 caractères. Lors de l'évènement onKeyPress sur ce champ, je contrôle le nombre de caractère de celui-ci.

Voila mon problème. Arrivé a 500 caractères, je ne peut plus rien faire. J'ai donc autorisé l'appui sur la touche retour arrière, les flèches et le bouton suppr, de manière a supprimer des caractères. Le souci, c'est qu'en utilisant la fonction keyCode, il se trouve que la touche suppr et le point (".") on le même code (46). Par conséquent, si je saisie une succession de points, je peut largement dépassé mon nombre limite de caractère.

Voila la fonction que j'utilise :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 
function verif_limite(e){
  var com = document.getElementById("new_com").value;
 
  if(!e){
    var e = window.event;
  }
 
  if(e.keyCode){
    code = e.keyCode;
  }
  else if(e.which) code = e.which;
 
  if(code != 8 && code != 46 && (code < 37 || code > 40) && com.length >= 500){
    e.returnValue = false;
    e.preventDefault();
  }
}
Quelqu'un aurais t'il une solution ?
Bugger24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/01/2011, 11h13   #2
Expert Confirmé Sénior
 
Avatar de RomainVALERI
 
Homme Romain VALERI
POOête
Inscription : avril 2008
Messages : 2 572
Détails du profil
Informations personnelles :
Nom : Homme Romain VALERI
Âge : 35
Localisation : France, Meurthe et Moselle (Lorraine)

Informations professionnelles :
Activité : POOête

Informations forums :
Inscription : avril 2008
Messages : 2 572
Points : 4 073
Points : 4 073
Je ne dis pas que c'est idéal dans ton contexte, mais la première chose qui me vienne serait :
Code javascript :
1
2
3
4
5
6
function verif_limite(e){
   var com = document.getElementById("new_com").value;
   if (com.length > 500) {
      document.getElementById("new_com").value = com.substring(0, 500);
   }
}
Mais du coup, ce n'est peut-être plus sur onkeypress que la verif doit etre faite... plutot sur onkeyup ?
__________________

...pour les linguistes et les curieux >>> générateur de phrases aléatoires

__________________
RomainVALERI est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/01/2011, 11h27   #3
Rédacteur/Modérateur
 
Avatar de SpaceFrog
 
Homme
Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Analyste Programmeur
Inscription : mars 2002
Messages : 30 007
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Royaume-Uni

Informations professionnelles :
Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Analyste Programmeur
Secteur : Industrie

Informations forums :
Inscription : mars 2002
Messages : 30 007
Points : 45 091
Points : 45 091
maxLength ?
__________________
Ma page Developpez
Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
Votre post est résolu ? Alors n'oubliez pas le Tag


réalisations :www.planet-languages.com|www.saftair.com| www.ouestisol.fr | www.sebemex.fr | www.extramiante.fr | www.sistac-alizay.fr | www.acoustishop.fr | www.litt.fr | www.ouestventil.fr
SpaceFrog est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/01/2011, 11h28   #4
Membre Expert
 
Avatar de Willpower
 
Homme Boris Dessy
sans emploi
Inscription : décembre 2010
Messages : 847
Détails du profil
Informations personnelles :
Nom : Homme Boris Dessy
Localisation : Belgique

Informations professionnelles :
Activité : sans emploi

Informations forums :
Inscription : décembre 2010
Messages : 847
Points : 1 346
Points : 1 346
Citation:
Envoyé par Bugger24 Voir le message
Bonjour a tous,

Je veut limiter la nombre de caractère saisie dans un <textarea> a 500 caractères. Lors de l'évènement onKeyPress sur ce champ, je contrôle le nombre de caractère de celui-ci.

Voila mon problème. Arrivé a 500 caractères, je ne peut plus rien faire. J'ai donc autorisé l'appui sur la touche retour arrière, les flèches et le bouton suppr, de manière a supprimer des caractères. Le souci, c'est qu'en utilisant la fonction keyCode, il se trouve que la touche suppr et le point (".") on le même code (46). Par conséquent, si je saisie une succession de points, je peut largement dépassé mon nombre limite de caractère.

Voila la fonction que j'utilise :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 
function verif_limite(e){
  var com = document.getElementById("new_com").value;
 
  if(!e){
    var e = window.event;
  }
 
  if(e.keyCode){
    code = e.keyCode;
  }
  else if(e.which) code = e.which;
 
  if(code != 8 && code != 46 && (code < 37 || code > 40) && com.length >= 500){
    e.returnValue = false;
    e.preventDefault();
  }
}
Quelqu'un aurais t'il une solution ?
http://forum.webrankinfo.com/maxleng...ea-t14299.html
Willpower est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/01/2011, 11h50   #5
Expert Confirmé Sénior
 
Avatar de RomainVALERI
 
Homme Romain VALERI
POOête
Inscription : avril 2008
Messages : 2 572
Détails du profil
Informations personnelles :
Nom : Homme Romain VALERI
Âge : 35
Localisation : France, Meurthe et Moselle (Lorraine)

Informations professionnelles :
Activité : POOête

Informations forums :
Inscription : avril 2008
Messages : 2 572
Points : 4 073
Points : 4 073
Citation:
Envoyé par SpaceFrog Voir le message
maxLength ?
Ou ça ? (pas ici en tout cas)

edit : au temps pour moi Il était ici ^^ merci SF !
Par contre, ça marche avec un input type="text" mais a priori pas avec textarea...
__________________

...pour les linguistes et les curieux >>> générateur de phrases aléatoires

__________________
RomainVALERI est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/01/2011, 11h51   #6
Rédacteur/Modérateur
 
Avatar de SpaceFrog
 
Homme
Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Analyste Programmeur
Inscription : mars 2002
Messages : 30 007
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Royaume-Uni

Informations professionnelles :
Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Analyste Programmeur
Secteur : Industrie

Informations forums :
Inscription : mars 2002
Messages : 30 007
Points : 45 091
Points : 45 091
Code :
1
2
3
4
5
6
<script type="text/javascript">
function LongMax(qui, combien)
{
  return (qui.value.length <= combien);
}
</script>
Code :
1
2
 
<textarea name="truc" onkeypress="return LongMax(this, 15);" ><textarea>
__________________
Ma page Developpez
Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
Votre post est résolu ? Alors n'oubliez pas le Tag


réalisations :www.planet-languages.com|www.saftair.com| www.ouestisol.fr | www.sebemex.fr | www.extramiante.fr | www.sistac-alizay.fr | www.acoustishop.fr | www.litt.fr | www.ouestventil.fr
SpaceFrog est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 01h11.


 
 
 
 
Partenaires

Hébergement Web