Systeme de like dislike jquery ,ajax et php
Résolu
ir_1997
Messages postés
97
Date d'inscription
Statut
Membre
Dernière intervention
-
jordane45 Messages postés 38483 Date d'inscription Statut Modérateur Dernière intervention -
jordane45 Messages postés 38483 Date d'inscription Statut Modérateur Dernière intervention -
A voir également:
- Like dislike javascript
- Coco like - Accueil - Réseaux sociaux
- Voir like instagram - Guide
- Telecharger javascript - Télécharger - Langages
- Comment retrouver un like sur facebook rencontre ✓ - Forum Facebook
- Si je like et dislike sur instagram - Forum Instagram
5 réponses
Bonjour
Ton premier problème est que tu cibles (dans ton JavaScript) tes boutons via leur id.
Visiblement tu as utilisé le même identifiant pour toud tes boutons ... Alors qu'un identifiant se doit d'être unique.
À la place, je t'invite à utiliser des class pour cibler des éléments.
Une fois cette modification effectuée, tu pourras retirer le JavaScript de ton include et le placer en dehors de ta boucle.
Ton premier problème est que tu cibles (dans ton JavaScript) tes boutons via leur id.
Visiblement tu as utilisé le même identifiant pour toud tes boutons ... Alors qu'un identifiant se doit d'être unique.
À la place, je t'invite à utiliser des class pour cibler des éléments.
Une fois cette modification effectuée, tu pourras retirer le JavaScript de ton include et le placer en dehors de ta boucle.
et je viens d'enlever la mon include dans la boucle
les like du premier article marche normalement
le seul souci et que lees like saffiche pas les autres articles
les like du premier article marche normalement
le seul souci et que lees like saffiche pas les autres articles
Tu n'as pas compris ce que je t'ai dit.
C'est uniquement le code javascript qu'il faut sortir de ta boucle.
Il faut modifier ton code JavaScript... Pour qu'il cible les différents boutons via, par exemple, une class et non les id...
L'as-tu modifié ?
As-tu mis des class sur tes boutons ?
As-tu utilisé c'est class dans le code JavaScript ?
C'est uniquement le code javascript qu'il faut sortir de ta boucle.
Il faut modifier ton code JavaScript... Pour qu'il cible les différents boutons via, par exemple, une class et non les id...
L'as-tu modifié ?
As-tu mis des class sur tes boutons ?
As-tu utilisé c'est class dans le code JavaScript ?
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bon,
Il y aurait encore mieux à faire.... mais bon, vu l'heure tardive je ne vais pas te faire réflechir trop longtemps...
Donc, En gros, ton code devrait ressembler à un truc du genre
(attention, je l'ai écrit de tête sans le tester.. il y aura peut-être des erreurs à corriger.... )
Fichier : likedislike.php
En dessous de ta boucle
Dans les idées d'amélioration .. au lieu d'utiliser deux fichiers php pour récupérer séparément les votes like et dislike, tu pourrais le faire avec un seul fichier .. une seule requête SQL et donc, un seul appel ajax.
D'ailleurs, pourquoi avoir fait deux tables différentes ??
Une seule table avec deux colonnes pour gérer les like ou dislike aurait été préférables ...
Table "vote" avec les champs : idarticle, like, dislike
PS: Il me semblait t'avoir déjà indiqué que la fonction htmlspecialchars ne s'utilise pas pour "sécuriser" les variables que tu utilises ensuite dans les requêtes... cette fonction n'est utile que pour de l'affichage dans du html
PS2 : Il me semblait également 'avoir déjà donné des consignes concernant l'écritures du code PDO
Pour rappel : https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
PS3 : J'avais également déjà dû te donner d'autres conseils ici : https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
Il serait peut-être temps que tu appliques les conseils ( consignes ! ) qu'on te donne .. sinon je ne vois pas l'intéret de continuer à te venir en aide.
Il y aurait encore mieux à faire.... mais bon, vu l'heure tardive je ne vais pas te faire réflechir trop longtemps...
Donc, En gros, ton code devrait ressembler à un truc du genre
(attention, je l'ai écrit de tête sans le tester.. il y aura peut-être des erreurs à corriger.... )
Fichier : likedislike.php
<p> <span class="gauche" > <button id="like_<?php echo $resultat['id'];?>" class="btn btn-outline-danger btn-like" data-id="<?php echo $resultat['id'];?>" ><div class="div_like" data-id="<?php echo $resultat['id'];?>" id="likes_<?php echo $resultat['id'];?>"></div>J'aime </button> </span> <span class="droite" > <button id="dislikes_<?php echo $resultat['id'];?>" class="btn btn-outline-success btn-dislike" data-id="<?php echo $resultat['id'];?>"><div class="div_dislike" data-id="<?php echo $resultat['id'];?>" id="dislike_<?php echo $resultat['id'];?>"></div>Je n'aime pas </button> </span> </p>
En dessous de ta boucle
<script type="text/javascript"> $(document).ready(function(){ $(".btn-like").click(function(){ var id = $(this).data('id'); $.post("reputation.php",{ t:"1" ,idarticle :id}, function(data){ $("#result").html(data); }); }); $(".btn-dislike").click(function(){ var id = $(this).data('id'); $.post("reputation.php",{t:"2",idarticle:id}, function(data){ $("#result").html(data); }); }); setInterval(function(){ $('.div_like').each(function(i,el){ var id = $(el).data('id'); $.post("likes.php", {likes:id}, function(data){ // Display the returned data in browser $("#likes_"+id).html(data); console.log(data); }); }); $('.div_dislike').each(function(i,el){ var id = $(el).data('id'); $.post("dislikes.php", {likes:id}, function(data){ // Display the returned data in browser $("#dislike_"+id).html(data); console.log(data); }); }); },100); }); </script>
Dans les idées d'amélioration .. au lieu d'utiliser deux fichiers php pour récupérer séparément les votes like et dislike, tu pourrais le faire avec un seul fichier .. une seule requête SQL et donc, un seul appel ajax.
D'ailleurs, pourquoi avoir fait deux tables différentes ??
Une seule table avec deux colonnes pour gérer les like ou dislike aurait été préférables ...
Table "vote" avec les champs : idarticle, like, dislike
- Au niveau requête, ça aurait simplement donné
SELECT idarticle, like, dislike FROM votes WHERE idarticle = ?'
PS: Il me semblait t'avoir déjà indiqué que la fonction htmlspecialchars ne s'utilise pas pour "sécuriser" les variables que tu utilises ensuite dans les requêtes... cette fonction n'est utile que pour de l'affichage dans du html
PS2 : Il me semblait également 'avoir déjà donné des consignes concernant l'écritures du code PDO
Pour rappel : https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
PS3 : J'avais également déjà dû te donner d'autres conseils ici : https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
Il serait peut-être temps que tu appliques les conseils ( consignes ! ) qu'on te donne .. sinon je ne vois pas l'intéret de continuer à te venir en aide.
Pour les like j’avais suivi un tuto c’est la j’ai pris l’idée des deux tables parce j’ai mis aussi une colonne pour l’ID de l’utilisateur
Ps2 pour le pdo j’avais pas oublié enfaite sa y est dans le code j’ai sauté sa pour publier en bref
PS3 c’est noté vais essayer de tout mettre et désolé d’être aussi chiant par fois ????
Ps2 pour le pdo j’avais pas oublié enfaite sa y est dans le code j’ai sauté sa pour publier en bref
PS3 c’est noté vais essayer de tout mettre et désolé d’être aussi chiant par fois ????
Pour les class des buttons pourquoi je peux pas utiliser les id
Parce j’utilise déjà bootstrap et sa identifie les button via les class ...
Et aussi
j’ai vraiment pas compris cette partie du code
Parce j’utilise déjà bootstrap et sa identifie les button via les class ...
Et aussi
j’ai vraiment pas compris cette partie du code
setInterval(function(){ $('.div_like').each(function(i,el){ var id = $(el).data('id'); $.post("likes.php", {likes:id}, function(data){ // Display the returned data in browser $("#likes_"+id).html(data); console.log(data); }); }); $('.div_dislike').each(function(i,el){ var id = $(el).data('id'); $.post("dislikes.php", {likes:id}, function(data){ // Display the returned data in browser $("#dislike_"+id).html(data); console.log(data); }); }); },100);
Un id ( id: qui veut dire identifiant) se doit d'être unique.
C'est comme toi avec ton nom et ton prénom.
Imagine que tout le monde s'appelle de la même manière quand tu veux parler à une personne précise comment fais-tu ?
Et c'est bien le car actuellement dans ton site web.
Tu as plusieurs fois un bouton like et un bouton dislike... Chacun de ses boutons toi avoir un identifiant unique.
Pour ce qui est d'attacher l'événement clic sur chaque bouton, on utilise comme sélecteur, une class.
Je ne vais pas passer ma soirée à te donner un cours... Je t'invite très fortement à suivre des cours sérieux concernant la programmation en javascript.
Suivre des tutoriels on ne faisons que copier coller les bouts de code trouver çà et là sans être en capacité de les comprendre ne te sert à rien !
Pour ma part je m'arrête là dans la discussion je te laisse poursuivre (ou plutôt devrais-je dire commencer....) Ta formation.
Bonne soirée.
C'est comme toi avec ton nom et ton prénom.
Imagine que tout le monde s'appelle de la même manière quand tu veux parler à une personne précise comment fais-tu ?
Et c'est bien le car actuellement dans ton site web.
Tu as plusieurs fois un bouton like et un bouton dislike... Chacun de ses boutons toi avoir un identifiant unique.
Pour ce qui est d'attacher l'événement clic sur chaque bouton, on utilise comme sélecteur, une class.
Je ne vais pas passer ma soirée à te donner un cours... Je t'invite très fortement à suivre des cours sérieux concernant la programmation en javascript.
Suivre des tutoriels on ne faisons que copier coller les bouts de code trouver çà et là sans être en capacité de les comprendre ne te sert à rien !
Pour ma part je m'arrête là dans la discussion je te laisse poursuivre (ou plutôt devrais-je dire commencer....) Ta formation.
Bonne soirée.