[PHP] Verif caractère dans un input et modif
RésoluMihawk Messages postés 4753 Statut Contributeur -
Je prépare un petit attrape nigot en php pour un projet de BTS ^^ !
Et j'aurais besoin de vos lumières...
Car dans un champ, j'aimerais :
Que si la personne met le caractère " . " (point), cela n'affiche pas le " . " mais un autre caractère et ainsi de suite jusqu'a ce qu'un " . " soit remis.
Les caractères donc "cachés" entre ces " . " seront enregistrés dans une variables par la suite...
Merci d'avance
et n'ésitez pas pour plus de précisions !
--
Digsaw
'Avoir une section fumer dans un restaurant, c'est comme avoir une section pisseur dans une piscine !'
- [PHP] Verif caractère dans un input et modif
- Caractère spéciaux - Guide
- Caractere speciaux - Guide
- Verif lien - Guide
- Caractère ascii - Guide
- Expert php - Télécharger - Langages
21 réponses
- 1
- 2
Un problème d'implémentation en PHP et JavaScript vise à masquer les caractères saisis entre des points et à capturer le contenu situé entre ces délimiteurs pour le stocker ensuite. Plusieurs répondants proposent une solution JavaScript qui, à chaque frappe, empêche l'affichage direct de la vraie réponse et construit "vraieReponse" à partir des caractères saisis. D'autres suggèrent l'usage d'un champ caché pour transmettre cette vraie réponse au serveur en PHP, via $_POST, afin de la récupérer lors de la soumission. Des échanges évoquent aussi les limites potentielles liées au comportement des navigateurs et à la synchronisation entre le script de remplacement et l'input, rendant la solution contextuelle.
Et y a les commentaires en bonus.
<script type="text/javascript">
// Définition des variables globales
vraieReponse = "";
reponseEnCours = false; // Permet de savoir si l'utilisateur est en train de taper une réponse
phraseAAfficher = "Voulez-vous répondre"; // Possibilité de la modifier si besoin
tCaracteresReponseEnAttente = new Array(); // Tableau servant de file afin de gérer les superpositions d'événements
/** Fonction cachant la réponse de l'internaute au fur et à mesure qu'il écrit
* Cette fonction est appelée à chaque fois qu'une touche est relachée sur le clavier
* @param : input : balise input modifiée par l'internaute
* @param : codeTouche : keyCode de la touche appuyée, permet de gérer les cas du backspace
**/
function cacherReponse(input, codeTouche){
if (input.value.match(/^V.+\./) && reponseEnCours == true){
// Quand l'utilisateur tape le 2e point, sa réponse est terminée : on "nettoie" l'input
input.value = "Voulez-vous répondre à ma question ?";
reponseEnCours = false
//alert("Debug - La réponse rentrée est : "+vraieReponse);
} else{
if (input.value.match(/\..*/) || reponseEnCours == true){
// Cas où l'utilisateur tape le premier point ou ce qu'il y a derrière
/* On enregistre le fait qu'on soit dans la réponse */
if (!reponseEnCours) reponseEnCours = true;
/* Conversion des chaînes en tableaux pour plus de facilité de manip' */
var tableauPhraseAAfficher = phraseAAfficher.split("");
var tailleReponseAvecPoint = input.value.length;
/* Gestion de la réponse "vraie" */
if (tailleReponseAvecPoint > 1 && (codeTouche > 48 || codeTouche == 32 /*espace*/)){
// Cas où on tape une touche écrivante (lettre, chiffre, espace...)
tCaracteresReponseEnAttente.push(String.fromCharCode(codeTouche));
completerReponse();
} else {
// Gestion des touches particulières
if (codeTouche == 8){
// Cas de la suppression d'un caractère (backspace)
var tChaineReponseActuelle = vraieReponse.split("");
vraieReponse = "";
for (var j=0 ; j<tChaineReponseActuelle.length-1 ; j++){
vraieReponse += tChaineReponseActuelle[j];
}
}
}
/* On efface l'input et on la recompose avec le même nombre de caractères
mais en piochant ceux-ci dans la phrase à afficher */
var boutAAfficher = ""
for (var i=0 ; i<tailleReponseAvecPoint ; i++){
if (i < tableauPhraseAAfficher.length){
boutAAfficher += tableauPhraseAAfficher[i];
} else {
// Si la réponse tapée dépasse le nombre de caractères de la phrase de remplacement, on comble avec des espace
boutAAfficher += " ";
}
}
input.value = boutAAfficher; // Enfin, on remplace au sein de l'input
}
else {
// Cas de frappe "normale"
if (reponseEnCours) reponseEnCours = false;
}
}
}
/** Méthode en charge du vidage de la file de caractère pour complétion de la réponse **/
function completerReponse(){
while (tCaracteresReponseEnAttente.length > 0){
vraieReponse += tCaracteresReponseEnAttente.shift().toLowerCase();
}
}
</script>
Je t'aiderai avec plaisir, mais j'ai besoin de plus de précision en effet. Déjà que signifie ton "ainsi de suite".
De ce que j'ai compris, la phrase :
"Bonjour à tous, je suis Mihawk. J'ai 23 ans et je suis au Lycée. Ca va ?"
Deviendrait :
"Bonjour à tous, je suis Mihawkerfgtdofthyrazzr'"(y-'fgerhtyjtfdsz Ca va ?"
C'est ça ?
Déjà merci de t'intéresser à mon sujet !
et non ce n'est pas exactement cela !
Le "ainsi de suite" je vais l'expliquer dans cette phrase :
l'utilisateur 'basic' et qui ne connais pas l'astuce tapera une phrase du genre : "Voulez vous répondre à ma question ?" (1)
Ici rien ne ce passe donc c'est bon.
L'utilisateur qui va jouer l'astuce va t'aper réellement sur son clavier :
" .RéponseAlaQuestion. à ma question ? " (2)
Le nombre de caractères de : " .RéponseAlaQuestion. " est de 20 et "remplace" les 20 premier caractères de la phrase (1).
Mais la phrase (2), n'est que ce que tape l'utilisateur. A l'écran sa afficherais la phrase (1).
J'imagine que c'est assez vague, mais c'est pas facil à expliquer.. ^^
J'aimerais que lorsque l'utilisateur marque un "." dans le champ ce point soit remplacer par une lettre précise (ici intervient le "ainsi de suite") car entre les 2 point se trouvera la réponse "cachée" d'une question !
Exemple :
L'utilisateur marque : ".MaRéponse. répondre à ma question ?"
à la validation cela marquera : MaRéponse
Mais ce MaRéponse est 'invisible' à l'écran, cela sera afficher come ceci : "Voulez vous répondre à ma question ?" (1)
je comprend que ça ne doit pas être facil à comprendre mais je suis présent pour des précision (encore ^^)
et merci pour l'aide !
Et au fur et à mesure qu'il écrit, cela se transforme en "Voulez-vous répondre à ma question ?" tout en conservant le "Une grenouille" dans une variable ?
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question.un.ez vous répondre à ma question ?
le 'un' sera dans une variable, mais à l'écran ça affichera bien : Voulez vous répondre à ma question ?
Tu t'y connais un peu ?
J'ai trouver comment faire une 'réponse' aléatoire a partir d'un tableau mais c'est pas très dur..
Parce qu'à mon avis, la meilleure solution ce sont les REGEX...
Tu repères si les deux points avec un truc au milieu est bien présent, si oui tu remplaces avec le "Voulez vous répondre" et tu stockes la réponse avec des parenthèses capturantes... Mais est-ce que tu connais le language REGEX?
Et pour le langage REGEX non je ne connais pas c'est la première fois que j'en entend parler... Comme dis précédemment je croyais que sa pouvais se faire en PHP...
Mais si tu me dis que le language REGEX est une bonne solution je suis tout à ton écoute ainsi que celle de Mihawk pour je JS...
Je suis d'accord avec Popoï_ : il va falloir utiliser des regexp dans la méthode onChange() du champ concerné.
Donc dans ta balise <input id="idDeMonInput"> du champ rempli par l'utilisateur, tu met un attribut : onChange="remplacerReponse(this.value);"
Ensuite tu va placer ailleurs dans ta page, ou dans une page .js source que tu insèreras dans la page du formulaire, la méthode javascript en question :
<script type="text/javascript">
function remplacerReponse(textParam){
textParam = textParam.replace(/\..+\./g, "Voulez-vous répondre");
document.getElementById("idDeMonInput").value = textParam;
}
</script>
En tout cas, quelque chose du genre. Après il risque en effet d'y avoir un soucis au niveau des métacaractères. Si ta réponse risque d'en contenir, il va falloir ajouter un replace en charge des les échapper.
Mais ne conaissant pas du tout le JS pouvez vous m'indiquez ce que je pourrais mettre à la place de 'textParam' ?
<form>
<input id="demande" type="text" style="width:500px" onKeyUp ="cacherReponse(this);">
</form>
<script type="text/javascript">
vraieReponse = ""; // Variable globale stockant la vraie réponse
function cacherReponse(input){
if (input.value.match(/\..+\./)){
vraieReponse = input.value.replace(/\.(.+)\./g, "$1");
var textCache = input.value.replace(/\..+\./g, "Voulez-vous répondre à ma question ?");
input.value = textCache;
alert(vraieReponse); // A supprimer ensuite
}
}
</script>
Tant qu'on ne fait pas, on ne sait pas.
Alors ce qui se pazsse c'est que lorsque l'utilisateur à tapé le deuxieme "." cela se "transforme" en : Voulez-vous répondre à ma question ?
Un très très bon début ! :) mais le alert n'affiche rien... enfin de ce que j'ai compris sa aurai du afficher ce qui avait entre les 2 "." ?
exemple :
lorsqu'il tape lettre à lettre
. = V
m = o
a = u
r = l
e = e
p = z
o = (espace)
n = v
s = o
e = u
. = s
le .mareponse. est bien évidemment toujours caché, et l'utilisateur (du moin l'arnaqueur) tape la fin de la question ici : répondre à ma question ?
Je précise que le nombre de caractères de .mareponse. peuvent variés...
Seul problème majeur : quand on tape doucement ça marche à merveille ; dès qu'on tape rapidement, les événements se mélangent et ça fait n'importe quoi !
Tu peux copier/coller ce code dans une page HTML à part et la faire tourner sous Mozilla ou autre pour tester, tu verras par toi-même.
<html>
<body>
<form>
<input id="demande" type="text" style="width:500px" onKeyUp ="cacherReponse(this, event.keyCode);">
</form>
<div id="test"></div>
</body>
</html>
<script type="text/javascript">
vraieReponse = "";
reponseEnCours = false;
phraseAAfficher = "Voulez-vous répondre";
function cacherReponse(input, codeTouche){
if (input.value.match(/^V.+\./) && reponseEnCours == true){
//alert("debug2");
input.value = "Voulez-vous répondre à ma question ?";
reponseEnCours = false
alert(vraieReponse); // A supprimer ensuite
} else{
if (input.value.match(/\..*/) || reponseEnCours == true){
//alert("debug1");
if (!reponseEnCours) reponseEnCours = true;
var tableauPhraseAAfficher = phraseAAfficher.split("");
var tableauCaracteres = input.value.split("");
if (tableauCaracteres.length > 1 && (codeTouche > 48 || codeTouche == 32 /*espace*//* Ajouter d'autres conditions de restriction des touches */)){
vraieReponse += tableauCaracteres[tableauCaracteres.length-1];
document.getElementById("test").innerHTML+=tableauCaracteres[tableauCaracteres.length-1];
} else {
if (codeTouche == 8){
// Cas de la suppression d'un caractère
var tChaineReponseActuelle = vraieReponse.split("");
vraieReponse = "";
document.getElementById("test").innerHTML = "";
for (var j=0 ; j<tChaineReponseActuelle.length-1 ; j++){
vraieReponse += tChaineReponseActuelle[j];
document.getElementById("test").innerHTML += tChaineReponseActuelle[j];
}
}
}
var boutAAfficher = ""
for (var i=0 ; i<tableauCaracteres.length ; i++){
if (i < tableauPhraseAAfficher.length){
boutAAfficher += tableauPhraseAAfficher[i];
} else {
boutAAfficher += " ";
}
}
input.value = boutAAfficher;
}
else {
//alert("debug3");
}
}
}
</script>
[EDIT] : code modifié !!
Tant qu'on ne fait pas, on ne sait pas.
J'ai simplement une question... lorsque je tape le premier "." tout va pour le mieu même si je tape vite et c'est génial ! et lorsque je tape le deuxieme "." la phrase " Voulez-vous répodnre à ma question ?" s'affiche d'un seul coup ..?
et un truc tout bête mais comment faire pour le la chaine stockée entre les "." soit enregistrée dans une variable pour que je puisse la mettre dans un champ en php ?
merci pour ce travail qui rend très bien, merci pour tout et pour tes efforts et le temps que tu y a passé !
- 1
- 2