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

jQuery Discussion :

Chat et jQuery [Gérer le mode Asynchrone]


Sujet :

jQuery

  1. #1
    Membre éclairé Avatar de Caxton
    Homme Profil pro
    Sans
    Inscrit en
    Janvier 2005
    Messages
    586
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Corrèze (Limousin)

    Informations professionnelles :
    Activité : Sans

    Informations forums :
    Inscription : Janvier 2005
    Messages : 586
    Par défaut Chat et jQuery [Gérer le mode Asynchrone]
    Bonjour,

    Pour informations:
    Mon précédent tread était liée à une reflexion stratégique sur la connexion au travers de jQuery. Ce problème étant résolu, afin de ne pas plus poluer mon post initial, j'ai pris la décision de le taggé résolu et d'ouvrir celui-ci qui va traiter de la construction de mon application en ajax.

    Le projet:
    Actuellement je tente de développer un t'chat en jquery. Je ne connaissait pas bien ce type de programmation et je m'y familiarise au fur et à la mesure des problématique à gérer. La partie Php ne me posant pas de problème, des essais ont été réaliser pour faire un retour et une exploitation en json, tout ce petit monde fonctionne à merveille.

    La problématique actuelle:
    Actuellement je suis en train de travailler sur le champ de saisie qui est un simple textarea. Celui-ci soit pouvoir prendre la saisie et un appuie sur la touche "entrer" évènement 13 provoque l'envoie du message dans la base d donnée. J'y suis pratiquement arrivé mais je bloque encore sur de nouveau points.

    En effet, je cherche maintenant à ne pas revenir à la ligne lorsque j'appuie sur entrée et en même temps une majuscule + entrer soit provoqué non pas l'envoie mais un saut de ligne.

    J'ai réussi à capturer la touche entrée en mode "keypress" mais je n'ai pas su trouver pour le majuscule + entrer.

    J'aimerais modifier le code suivant pour réaliser ce comportement, si c'est possible.
    Code : 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
     
    //La gestion de l'envoie d'une sasie au serveur
    $(document).ready( function() {
     
    	$('#chatForm').bind('keypress', function(e) {
     
            //Touche entrée
            if(e.keyCode==13){
     
                //Charge la saisie dans la variable
                gSaisie = $('#cSaisie').val();
     
                //Si la siaise n'est pas vide
                if(gSaisie) {
     
    				//Effacer le champ de saisie
    				$('#cSaisie').val('').focus();
     
    				//Envoie au serveur une requête de saisie dans le bon canal avec l'id du pseudo
    				alert('[' + Pseudo + ']: ' + gSaisie);
     
                                    //Evite un saut de ligne (existe-t-il une meilleure solution ?)
    				return false;
    			}
            }
    	});
    });
    La conclusion:
    Pour le moment j'ai volontairement mis un alert() à la place de l'envoie de la requête car je procède à un débuggage progressif. Cette ligne sera remplacé par du requêtage en ajax, dans le futur.

    Remerciement:
    Je remercie déjà, alors que je n'ai aucune réponse, pour l'aide que vous me porterais.

  2. #2
    Membre extrêmement actif
    Avatar de Golgotha
    Homme Profil pro
    Full-stack Web Developer
    Inscrit en
    Août 2007
    Messages
    1 387
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Full-stack Web Developer
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2007
    Messages : 1 387
    Billets dans le blog
    1
    Par défaut
    Je pense que la FAQ Jquery est assez complète sur ce point :

    Comment puis-je intercepter les frappes multitouches ?
    Consultant et développeur full-stack spécialiste du Web
    faq jQuery - règles du forum - faqs web

  3. #3
    Membre éclairé Avatar de Caxton
    Homme Profil pro
    Sans
    Inscrit en
    Janvier 2005
    Messages
    586
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Corrèze (Limousin)

    Informations professionnelles :
    Activité : Sans

    Informations forums :
    Inscription : Janvier 2005
    Messages : 586
    Par défaut
    Oui j'y suis aller avant de poster
    Mais je songeais plus une fois la capture réalisé. Est-ce que le return false; est la bonne solution ?

    Merci.

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 661
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : Royaume-Uni

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

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 661
    Billets dans le blog
    1
    Par défaut
    Vu que ça doit être à peu près la seule ...
    Ma page Developpez - Mon Blog 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

    Venez sur le Chat de Développez !

  5. #5
    Membre éclairé Avatar de Caxton
    Homme Profil pro
    Sans
    Inscrit en
    Janvier 2005
    Messages
    586
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Corrèze (Limousin)

    Informations professionnelles :
    Activité : Sans

    Informations forums :
    Inscription : Janvier 2005
    Messages : 586
    Par défaut
    Hey, justement, il serait intéressant de complémenté

    Bon ceci dit, j'ai pas encore trouvé comment attribuer à mon textarea un saut de ligne sur le maj+enter.

    Je pense à un $('#champSaisie').??? Voila c'est ça quand on débute, il y a des ??? à remplacer par des choses que l'on ne connais pas encore

  6. #6
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 661
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : Royaume-Uni

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

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 661
    Billets dans le blog
    1
    Par défaut
    un += sur le html ?
    Ma page Developpez - Mon Blog 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

    Venez sur le Chat de Développez !

  7. #7
    Membre éclairé Avatar de Caxton
    Homme Profil pro
    Sans
    Inscrit en
    Janvier 2005
    Messages
    586
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Corrèze (Limousin)

    Informations professionnelles :
    Activité : Sans

    Informations forums :
    Inscription : Janvier 2005
    Messages : 586
    Par défaut
    C'est bon, je suis arrivé à faire un comportement correct.

    Je passe maintenant à la partie rigolote du programme. L'asynchrone.

    Je sait que l'ajax, le jquery aussi peut effectuer des traitements asynchrones. Je me demandais si, dans mon js, je ne ferais pas une fonction qui irais chercher toutes les 2 secondes dans une bdd les nouveaux messages. Et à ce sujet, j'aimerais avoir quelques informations.
    • Faut-il partir d'un timer puis lancer une fonction qui contiendrais un appel en jquery ?
    • Faut-il partir d'un jQuery, placer son timer et donc son exécution indépendamment d'une fonction ?
    • Au final j'aurais deux zones qui doivent aller chercher des informations qui leurs sont propres, soit je me base sur le même timer, soit je fais un timer séparé de 2 et 3 secondes.


    J'ai regardé des cas similaires mais je n'ai pas encore su trouver l'exactitude du fonctionnement que j'aurais à écrire. J'espère donc déjà dégrossir le terrain avec la demande ci-dessus. Je pense qu'au fil de la conversation de nouvelles questions seront de mise pour en apprendre un peu plus. L'idéal étant quand même de resté encapsulé dans le jQuery.

    Merci

  8. #8
    Membre éclairé Avatar de Caxton
    Homme Profil pro
    Sans
    Inscrit en
    Janvier 2005
    Messages
    586
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Corrèze (Limousin)

    Informations professionnelles :
    Activité : Sans

    Informations forums :
    Inscription : Janvier 2005
    Messages : 586
    Par défaut
    Ça peut semblé stupide...
    J'ai trouvé un élément de réponse tardif

    J'ai vue dans un exemple la chose suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    //Ici je suppose que toutes les 2500 ms on va lancer une fonction.
    //Est loadChat ou loadChat() qu'il faut marqué ici ?
    setInterval(loadChat, 2500);
     
    function loadChat() {
       //Ici on trouve un jQuery allant cherché sur un fichier php des informations
       //Je suppose que c'est la BDD
       //success:
          //Mettre à jour la div
       //Erreur:
          //Mettre à jour la div
    }
    Je pense avoir compris le principe (reprenez-moi si je me trompe).
    Comment après on fait pour la liste des canaux et les personnes connectés/déconnectés ?

  9. #9
    Membre extrêmement actif
    Avatar de Golgotha
    Homme Profil pro
    Full-stack Web Developer
    Inscrit en
    Août 2007
    Messages
    1 387
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Full-stack Web Developer
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2007
    Messages : 1 387
    Billets dans le blog
    1
    Par défaut
    Il faut pas oublier que tu devra gerer un index dans ta base de donnée et dans ton javascript ou php pour ne pas ré-afficher les messages en double.

    Par exemple dans ta BDD tu as :

    0
    *
    *
    110 - "salut !"
    111 - "salut golgotha"
    112 - "ça va"
    113 - "oui et toi"
    114 - "bien bien"

    L'utilisateur qui arrive va peut etre listé les 5 derniers messages, bon ça c'est facile, une requette en ajax sur les 5 derniers, ensuite dans ta page tu doit mettre à jour ton index à 114, puis à chaque envoie de ta requêtes ajax tu envoie cette index, pour pouvoir faire la requete, si il y à des données supérieur à 114 alors, je renvoie toutes ces données, puis je met à jour mon index.

    Il faut aussi gérer ça quand tu envoie un message, changement d'index et récupération des messages posté avant.

    j'espère que cette réfléxion t'aidera
    Consultant et développeur full-stack spécialiste du Web
    faq jQuery - règles du forum - faqs web

  10. #10
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Billets dans le blog
    125

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  11. #11
    Membre éclairé Avatar de Caxton
    Homme Profil pro
    Sans
    Inscrit en
    Janvier 2005
    Messages
    586
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Corrèze (Limousin)

    Informations professionnelles :
    Activité : Sans

    Informations forums :
    Inscription : Janvier 2005
    Messages : 586
    Par défaut
    Aucun intérêt de prendre un plugin...

    Je préfère apprendre et codé moi-même

    Merci toutefois de ta contribution qui n'a rien à voir avec ma demande.

Discussions similaires

  1. [jQuery] Gérer la réponse AJAX
    Par Tchupacabra dans le forum jQuery
    Réponses: 3
    Dernier message: 10/06/2008, 12h48
  2. Réponses: 6
    Dernier message: 22/04/2008, 19h29
  3. Réponses: 1
    Dernier message: 15/02/2008, 19h40
  4. [.NET] Une question technique a propos du mode asynchrone
    Par nicknolt dans le forum Général Dotnet
    Réponses: 4
    Dernier message: 08/06/2004, 11h07

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