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

JavaScript Discussion :

Passage de variables dans une fonction


Sujet :

JavaScript

  1. #1
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut Passage de variables dans une fonction
    Bonjours à tous,

    J'ai une fonction qui remplit automatiquement un champ de formulaire à partir d'un bouton radio d'un autre formulaire...sauf qu'une des deux variables ne passe pas. (je suis débutant )

    la fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    function ChoisirBanniereJpg(nomBanniere,dim) 
    { 
       document.forms['formu'].elements['ban'].value = nomBanniere; 
       if(nomBanniere == ""+nomBanniere+"") 
       {
       document.getElementById ("banniere").src="bannieres/"+dim+"/"+nomBanniere+"";
       } 
       else
       {
       document.getElementById("banniere").src="bannieres/banniere1.jpg"; 
       }
    }
    puis l'appel de la fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $input = "<input type='radio' name='ban' onClick='window.close()'
    onChange='window.opener.ChoisirBanniereJpg(this.value, '.$dim.')' value='$Picturename'>"
    je précise que la variable php $dim est bien définie.

    et enfin l'endroit où j'affiche l'image sélectionnée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <img src="javascript:ChoisirBanniereJpg()">
    Sans la variable dim passée en argument mais définie dans la fonction
    var dim = "468x60";
    ça fonctionne très bien et l'image s'affiche...
    Alors je comprends pas que ve ne soit pas le cas quand la var est en argument.
    Si quelqu'un voit le prob, merci de son coup de main.

  2. #2
    Membre confirmé Avatar de supermanu
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    330
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 330
    Points : 452
    Points
    452
    Par défaut
    Pour la balise <img>
    - Il faut un id car tu fais document.getElementById ("banniere")
    - J'ai mis un fichier par défaut et non une fonction javascript.
    Ce qui donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <img id="banniere" src="bannieres/chien.jpg">
    Pour la balise <input>
    Je crois qu'il y a un problème avec '.$dim.' car au final tu dois avoir
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <input type="radio" id="ban" name="ban" onChange='ChoisirBanniereJpg(this.value, "468x60");' value='chat.jpg'/>
    à noter les " de chaque côté, c'est une chaîne de caractère.
    t'as balise est bien comprise dans un formulaire nommé formu ?

  3. #3
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut
    Bonjour et merci pour ta réponse, je vais essayer de préciser mieux parce que je galère toujours avec ça...

    D'abord le formulaire qui permet de choisir l'image grace à un bouton radio
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    <input type=\"radio\" name=\"ban\" onClick=\"window.close()\"
    onChange=\"window.opener.ChoisirBanniere(this.value,$dim)\" value=\"$Picturename\">
    La variable $dim est correctement définie: il s'agit, par exemple de 468x60 car mes bannières peuvent être dans un dossier bannieres/468x60

    Ensuite la page qui utilise la fonction
    la fonction elle même

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    function ChoisirBanniere(nomBanniere,dim) 
    { 
       document.forms['formu'].elements['ban'].value = nomBanniere; 
       if(nomBanniere == ""+nomBanniere+"") 
       {
       document.getElementById("banniere").src="bannieres/"+dim+"/"+nomBanniere+"";
       } 
    }
    A noter que la ligne
    document.forms['formu'].elements['ban'].value = nomBanniere;
    ne sert qu'à remplir un champ text du formulaire "formu" et qui affiche la var nomBanniere. Ca fonctionne bien, le nom de la ban s'affiche dans le champ texte.
    C'est l'affichage de la bannière qui cloche...Et je n'ai aucune erreur JS signalée. Voici la ligne qui l'appelle.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    <img src="javascript:ChoisirBanniere()" border="0" id="banniere">
    Et j'ai bien l'impression que la source image lue dans la fonction est "bannieres/nomBanniere" au lieu de "bannieres/468x60/nomBanniere comme si la variable dim n'était pas comprise. Car si je tape le chemin en clair dans la fonction
    document.getElementById("banniere").src="bannieres/468x60/"+nomBanniere+"";
    Elle s'affiche !
    à s'arracher les cheveux !!!

  4. #4
    Membre confirmé
    Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    430
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2006
    Messages : 430
    Points : 557
    Points
    557
    Par défaut
    salut,

    comme l'a dit supermanu, il faut que le contenu de $dim soit entouré, au final, par des quotes (ou guillemets, suivant les autres caractères choisis comme début/fin de chaîne)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <input type=\"radio\" name=\"ban\" onClick=\"window.close()\"
    onChange=\"window.opener.ChoisirBanniere(this.value,'$dim')\" value=\"$Picturename\">
    avec ca, ton passage de variable devrait déjà mieux... heu... se passer

  5. #5
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut
    Merci à vous deux !
    Des fois ça tient vraiment pas à grand chose !
    Bonne journée.

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

Discussions similaires

  1. Passage de variable dans une fonction
    Par francoism514 dans le forum Langage
    Réponses: 1
    Dernier message: 29/10/2011, 01h04
  2. [PHP-JS] Passage de variables dans une fonction
    Par Cassiope dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 13/05/2008, 17h01
  3. Réponses: 6
    Dernier message: 24/12/2004, 17h46
  4. Passage de variable dans une requête
    Par zestrellita dans le forum Langage SQL
    Réponses: 5
    Dernier message: 02/09/2004, 14h27
  5. [langage] Passage de paramètres dans une fonction
    Par And_the_problem_is dans le forum Langage
    Réponses: 11
    Dernier message: 28/06/2004, 09h20

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