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

AJAX Discussion :

Récupérer texte d'une div après chargement AJAX


Sujet :

AJAX

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juin 2018
    Messages
    56
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 29
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2018
    Messages : 56
    Par défaut Récupérer texte d'une div après chargement AJAX
    Bonjour j'ai fait un calendrier en PHP. Donc mes dates sont dans des TD qui ont était créer avec un for each.
    Dans mes TD j'ai une DIV avec une class "daytitle" qui correspond à la date entière "1janvier1999".

    Au clique sur les TD je charge un formulaire en AJAX avec une fonction toute simple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    function onClickDate(event){
            $('.reservation').load("formulaireajax.html");
    }
    J'ai essayer mainte et mainte solution mais je n'y arrive toujours pas.
    J'aimerais qu'au clique sur mes TD, je récupere le contenu de ma DIV "daytitle" donc la date entière, et qu'elle s'affiche dans la page du formulaire dans un p déjà créer avec l'id "textcontent".

    Quelqu'un pourrait m'aider ??
    Ca fait trois jours que je bloque je commence à déprimée

  2. #2
    Membre extrêmement actif Avatar de psychadelic
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    2 532
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 2 532
    Par défaut
    Quleque chose dans ce genre ?
    Code JavaScript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $('body').on( "click", "td", function(e) {
      let $_InDateTD = $(this).find('.daytitle');
      if ($_InDateTD.length > 0) {                      // il existe
        $('#textcontent').text( $_InDateTD.text() );
      }
    }

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

    Si la table est créé via Ajax, elle n'existait pas dans le DOM au chargement.
    Les td non plus.

    Il faut "raccrocher" l'événement à un élément présent au départ.
    Par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $('body').on( "click", "td", function(e) {
    ...

  4. #4
    Membre averti
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juin 2018
    Messages
    56
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 29
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2018
    Messages : 56
    Par défaut
    Citation Envoyé par psychadelic Voir le message
    Quleque chose dans ce genre ?
    Code JavaScript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $('body').on( "click", "td", function(e) {
      let $_InDateTD = $(this).find('.daytitle');
      if ($_InDateTD.length > 0) {                      // il existe
        $('#textcontent').text( $_InDateTD.text() );
      }
    }
    Alors je pense que ça doit être quelque chose comme ça mais ça me fait une erreur en fin de fichier ") attendu" n'importe ou ou je le place je comprend pas pourquoi. Franchement j'ai fait une formation de 3mois qui était plus axer sur le php; j'ai du mal avec jQuery et javascript c'est horrible
    Sinon non les td sont bien présente dans le DOM puisque généré en php sur une page phtml

  5. #5
    Membre extrêmement actif Avatar de psychadelic
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    2 532
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 2 532
    Par défaut
    c'est qu'il te manque une parenthèse fermante quelque part dans ton script.

    Utilise la coloration syntaxique ansi que Beautify, et Lint dans ton EDI, ça permet d'éviter ce genre d'erreur en codant.

    Si tu n'utilise pas d'EDI télécharge un EDI commeVisual Studio Code, ça simplifie pas mal l'écriture de code.

  6. #6
    Membre averti
    Femme Profil pro
    Développeur Web
    Inscrit en
    Juin 2018
    Messages
    56
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 29
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2018
    Messages : 56
    Par défaut
    Je code justement avec Visual Studio !
    Ben non franchement je vois pas ou il me manque une fermeture :
    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
    28
    'use strict';
    var caseDates = document.querySelectorAll("td");
    var caseDate;
    //on récupere la date entiere "1er janvier 1999"
     
    // on utilise jQuery pour afficher le mois correspond à chaque click et cacher les autres, on commence par afficher le premier mois
      jQuery(function($){
                $('.month-relative').hide();
                $('.month-relative:first').show();
                var current = 1;
                $('.mois a').click(function(){
                    var month = $(this).attr('id').replace('linkMonth','');
                    if(month != current){
                        $('#month'+ current).slideUp();
                        $('#month'+ month).slideDown();
                        $('.month a#linkMonth'+month);
                        current= month;
                    }
                    return false;
                })
                })
     
                $('body').on( "click", "td", function(e) {
                    let $_InDateTD = $(this).find('.daytitle');
                    if ($_InDateTD.length > 0) {                      // il existe
                      $('#textcontent').text( $_InDateTD.text() );
                    }
                }
    Par contre on m'as donner cette solution qui fait presque ce que je veux :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $('td').on('click', function() {
      var value = $(this).text(); // On récupère la date de la cellule
     
      $('.reservation').load('formulaireajax.html', function() {
        $('.reservation #textcontent').text('Vous avez choisi le ' + value); // Une fois le formulaire chargé, on remplace le contenu de textcontent
      });
    Qui sur le coup me fait enlever les ecouteur d'evement et la boucle pour les répeter, et j'ai réussi a selectionner ma div toute seule (oui ! ) donc c'est génial.

    Par contre j'ai cette erreur xhr qui s'affiche dans la console et sincèrement c'est pas de mon domaine encore lol
    "L’utilisation d’XMLHttpRequest de façon synchrone sur le fil d’exécution principal est obsolète à cause de son impact négatif sur la navigation de l’utilisateur final. Consulter http://xhr.spec.whatwg.org/ pour plus d’informations."
    Et sincèrement je sais pas du tout comment la résoudre

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

Discussions similaires

  1. Afficher une DIV après chargement du document ?
    Par tjoce05 dans le forum jQuery
    Réponses: 3
    Dernier message: 23/03/2015, 16h27
  2. [AJAX] Rafraîchir une DIV après requête AJAX
    Par TheBleedz dans le forum jQuery
    Réponses: 6
    Dernier message: 05/12/2013, 19h10
  3. Récupérer la totalité du texte d'une div
    Par ireolax dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 25/03/2012, 20h56
  4. Réponses: 3
    Dernier message: 05/07/2008, 19h09
  5. Récupèrer texte d'une div
    Par Invité(e) dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 19/06/2007, 18h10

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