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...
Et voila la version finale ! Attention, la réponse sera forcément convertie tout en minuscules et les ponctuations sont mal gérées par le traitement ! En revanche j'ai ajouté une file qui permet les superpositions d'événements, on peut donc taper aussi vite qu'on veut :-)
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 ?"
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 ^^)
Genre le mec écrit : .Une grenouille. à ma question ? 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 ?
Ok, bon passons aux choses sérieuses : tu veux faire de la modification temps réel d'un champ ; le langage de prédilection est donc le Javascript.
Tu t'y connais un peu ?
Ha non pas du tout... je pensais que ce serait possible à faire en PHP avec une fonction ou autre...
J'ai trouver comment faire une 'réponse' aléatoire a partir d'un tableau mais c'est pas très dur..
On pourra mettre des caractères comme "^ . [ ] $ ( ) * + ? | { } \" ?
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?
Les points d'interrogations seront présents oui enfin du moin un seul mais le reste non sa resera une simple question...
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...
Hello,
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 :
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.
Rien du tout ! Regarde le code : la fonction est appelée avec comme paramètre : "this.value" c'est à dire avec le contenu de la balise input.
[EDIT] : "rien du tout" signifie que tu laisses "textParam" !
Confirmes-tu que le "demande" est bien l'ID de l'input modifiée par l'utilisateur ; et que tu as bien ajouté l'événément "onChange" sur ce même input ?
Comme sa sera un projet présenté par mes soins je vais pas leur demander les questions sa sera des trucs simple ^^ ! On va pas gérer ce cas enfin du moin pas pour le moment !
OU alors je pense qu'un if avce une condition pourrais régler le problème non ? si la phrase > 20 alors question = Voulez vous répondre à ma question s'il vous plais monsieur ou madame.. ^^ je sais pas
Voici un code qui fonctionne. J'ai ajouté un div avec l'ID "test" pour voir en temps réel l'avancement de la vrai réponse (accessible via la variable globale "vraieReponse").
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>
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é !