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

Langage PHP Discussion :

Suppression d'un sujet ou message en AJAX


Sujet :

Langage PHP

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Junior
    Inscrit en
    Septembre 2021
    Messages
    70
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Junior

    Informations forums :
    Inscription : Septembre 2021
    Messages : 70
    Points : 30
    Points
    30
    Par défaut Suppression d'un sujet ou message en AJAX
    Bonjour,

    Je travaille actuellement sur un forum et souhaiterai avoir la possibilité de supprimer un post ou sujet avec un bouton delete en AJAX.
    J'ai suivi quelques tuto sur la méthode fetch et testé un code dans ce genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    document.getElementById("suppr").addEventListener("onClick", function(e){
     
        e.preventDefault();
     
        const url = this.href;
        console.log(url);
     
        fetch(url, {
            method: "DELETE"
        })
            .then(function(response) {
                alert(response);
            })
    })
    Ce qui ne fonctionne absolument pas. Je sais que le preventDefault on peut l'utiliser sur le submit d'un formulaire pour éviter le rechargement de la page. Du coup j'ai fais la meme chose avec le bouton delete mais ça ne prend pas en compte ce code.

    Si vous aurez quelques tuyaux je serai preneur, j'ai regardé un peu partout sur le net je n'ai pas trouvé de solutions.

    Merci d'avance !

  2. #2
    Inactif  
    Homme Profil pro
    Webmaster
    Inscrit en
    Juin 2021
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juin 2021
    Messages : 645
    Points : 1 280
    Points
    1 280
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    addEventListener("click",...

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Junior
    Inscrit en
    Septembre 2021
    Messages
    70
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Junior

    Informations forums :
    Inscription : Septembre 2021
    Messages : 70
    Points : 30
    Points
    30
    Par défaut
    Merci c'est corrigé. Par contre je ne vois pas quoi mettre dans le then. J'ai toujours ma page qui se recharge.

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Junior
    Inscrit en
    Septembre 2021
    Messages
    70
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Junior

    Informations forums :
    Inscription : Septembre 2021
    Messages : 70
    Points : 30
    Points
    30
    Par défaut
    Bonjour,

    Je reviens vers vous à ce sujet. Je ne sais pas comment supprimer un sujet en ajax. On est d'accord que le preventDefault va ici empêcher d’accéder au lien ?

    C'est comme si le prevendtDefault était ignoré.

    Si vous avez une idée, merci.

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Junior
    Inscrit en
    Septembre 2021
    Messages
    70
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Junior

    Informations forums :
    Inscription : Septembre 2021
    Messages : 70
    Points : 30
    Points
    30
    Par défaut
    J'ai pu avancé un peu sur le schmilblick.
    Maintenant quand je clique sur le bouton de suppression ça fonctionne bien, le sujet est bien supprimé de la bdd. Le preventDefault est bien pris en compte et l'url du bouton href également (j'ai remplacé this.href par item.href). Par contre la ligne ne disparait pas en live, il faut que je recharge la page pour voir la ligne disparaitre.

    Mon dernier code en date

    Code JavaScript : 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
    let deleteButton = document.querySelectorAll('.suppr').forEach(item => {
     
        item.addEventListener('click', (e) => {
            e.preventDefault();
     
            const url = item.href;
            console.log(url);
     
            fetch(url, {
                method: 'GET'
            })
                .then(response => response)
                .then(response => console.log(response));
        })
     
    });

    Le log de la reponse

    Nom : Capture.PNG
Affichages : 61
Taille : 7,7 Ko

    Si vous pouvez m'aider à faire en sorte que la ligne disparaisse au click.

  6. #6
    Expert confirmé Avatar de Toufik83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    2 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2012
    Messages : 2 453
    Points : 4 978
    Points
    4 978
    Par défaut
    Bonjour,

    Si le bouton .suppr est sur la même ligne que tu veux supprimer, tu peux revenir à son parent supérieur avec closest('tr').
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    ...
    .then(response => response)
    .then(response ()=> {
      console.log(response);
      if(response.ok===true){
        //le tr est le parent supérieur du bouton .suppr 
        item.closest("tr").remove();
      }
    });

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Junior
    Inscrit en
    Septembre 2021
    Messages
    70
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Junior

    Informations forums :
    Inscription : Septembre 2021
    Messages : 70
    Points : 30
    Points
    30
    Par défaut
    Merci beaucoup pour ta réponse ça fonctionne enfin !

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

Discussions similaires

  1. [AJAX] Alternative pour Response.Write("Message") avec Ajax UpdatePanel
    Par zakaria_jd dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 29/01/2008, 11h42
  2. Réponses: 2
    Dernier message: 29/01/2008, 11h41
  3. Réponses: 2
    Dernier message: 05/05/2006, 15h49

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