joujma5
Messages postés152Date d'inscriptionsamedi 11 novembre 2006StatutMembreDernière intervention 5 décembre 2014
-
10 mai 2010 à 22:51
Morphinof
Messages postés255Date d'inscriptionvendredi 20 avril 2007StatutMembreDernière intervention 9 août 2013
-
11 mai 2010 à 14:16
bonsoir,j'ai un code sur le quelle je travail depuis un moment et chaque fois je m'aperçoit une erreur,mon problème réside dans le fait que je veux bloquer les boutons qui incrémentent et décrémentent la quantité demandée d'un article lorsque je clique sur valider,tout se passe bien si j'ai un seul article dans le panier mais si jamais j'ajoute de plus les boutons s'affichent.le code est le suivant:
/*************************************************************************************************
** programme principal **
*************************************************************************************************/
if ($page->maj) {
// si on doit afficher commander on cree une variable $code qui va contenir le code du javascript
// permettant d'afficher le bouton "commande" et de cacher le bouton "valider"
// sinon on crée une variable $code qui permet de faire le contraire
if ($showHide) {
Morphinof
Messages postés255Date d'inscriptionvendredi 20 avril 2007StatutMembreDernière intervention 9 août 20134 11 mai 2010 à 13:43
Je n'ai pas tout ecrit mais je vais te re-expliquer le principe :
Ton idee c'est de test si tu est en mise a jour d'une page et donc si c'est le cas tu adapte ta fonction javascript pour qu'elle s'occupe de cacher tes boutons.
Seulement tu leur a tous donne le meme id a tes bouton c'est ca le souci car quand tu fait un document.getElementById le javasacript ne va pas savoir les differencier et va selement recursivement parcourir l'abre DOM, trouver ton PREMIER bouton ayant l'id demander et dire ah ok le voila.
C'est pour sa que sa marche avec un seul produit vu que tu n'a qu'un seul bouton qui s'appelle "plus" et un seul "minus".
Pour corriger le tir ce que je te mettait au dessus va permettre de differencier tes bouttons en leur donnant un id unique, je vais te detailler ca avec que le bouton plus vu que c'est la meme chose pour le minus :
Voici le lien que tu genere :
[# ]
Comme on peu le voir ton img a pour id "plus" pour chacun de tes articles.
Si tu rajoutes ta variable $numserie a leur id tu vas pouvoir les identifier de maniere sure dans ta page, il faudrai donc generer :
[# ]
maintenant toutes tes images ayant un id comme suit : "plus_tonNumeroDeSerie" tu va pouvoir les cacher toutes en generant le javascript suivant a la place de l'actuel en changeant les lignes que j'ai corriges :
Morphinof
Messages postés255Date d'inscriptionvendredi 20 avril 2007StatutMembreDernière intervention 9 août 20134 11 mai 2010 à 10:55
Ah j'ai eu du mal comprendre ce que tu voulais dire mais il est pourtant si evident que c'est normal que sa marche avec 1 article et pas x article ! :D
Alors ? :) Non toujours pas ?
D'accord alors en fait ce qui ce passe c'est que ton javascript ne desactive que une seule balise plus et minus car tu utilise getElementById, un id etait unique sa en desactive qu'un seul et c'est le premier trouve ! Meme si tout tes autres boutons on l'id minus sa suffit pas du tout !
Alors voici une solution :
Ca serait de generer l'id de tes boutons comme sa :
'panier->article as $numserie => $val) {
...
$code .='
document.getElementById("plus_'.$numserie.'").style.display="none";
document.getElementById("minus_'.$numserie.'").style.display="none";
...
}
Mais je te conseilles d'essayer d'en trouver une meilleure plutot orientee php ^^