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 :

[AJAX] MaFonction is not defined sous FF mais pas sous IE


Sujet :

JavaScript

  1. #1
    Membre régulier
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2004
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2004
    Messages : 105
    Points : 80
    Points
    80
    Par défaut [AJAX] MaFonction is not defined sous FF mais pas sous IE
    Bonjour à tous,

    J'ai une page avec des listes déroulantes qui se chargent dynamiquement les unes en fonction des autres et ce, via des scripts Ajax.

    J'ai donc le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <select name="choix_acteur" id="id_acteur" onChange="javascript:affiche_film();affiche_boxoffice();">
    // chargement du contenu via PHP/SQL
    </select>
     
    <div class="affiche_film" id="id_film" style="display:inline">
    <select name='choix_film'>
    	<option value='-1'>--- choix film ---</option>
    </select>
    </div>
    Et voici ma fonction affiche_film :
    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
    function affiche_film(){
    var idcode = null;
    var sel = null;
     
    var xhr2 = getXhr();
     
    // On defini ce qu'on va faire quand on aura la reponse
    xhr2.onreadystatechange = function()
    {
    // On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    	if(xhr2.readyState == 4) {
    		leselect = xhr2.responseText;
    		// On se sert de innerHTML pour rajouter les options a la liste
    		document.getElementById('id_film').innerHTML = leselect
    	}
    }
     
    // Ici on va voir comment faire du post
    xhr2.open("POST","index.php?p=AjaxFilm",true);
    xhr2.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); 
    sel = document.getElementById('id_acteur');
    idcode = sel.options[sel.selectedIndex].value;
    xhr2.send("id_acteur="+idcode);
    }
    J'ai donc une erreur "affiche_film is not defined" sous FF alors que sous IE, tout fonctionne !!!

    Avez-vous une idée ???

    Merci d'avance.

  2. #2
    Membre expérimenté
    Avatar de ryan
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2003
    Messages
    956
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2003
    Messages : 956
    Points : 1 316
    Points
    1 316
    Billets dans le blog
    1
    Par défaut
    Yop!

    Apparemment, FF attend une syntaxe différente pour faire référence à l'option sélectionnée.

    Avec ceci, je ne vois pas d'erreur dans la console.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    idcode = sel.options.selectedIndex.value;
    Pour éviter ce problème de compatibilité, il vaudrait mieux envoyer la valeur sélectionnée dans l'appel de la fonction:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <select name="choix_acteur" id="id_acteur" onChange="affiche_film(this.options[selectedIndex].value);">
    (Bizarrement, cette syntaxe fonctionne dans ce contexte, alors que dans une fonction, elle ne fonctionne pas. Il faudrait demander pourquoi aux gurus du forum Javascript)

    Et la récupérer ainsi:
    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
     
    function affiche_film(idcode){
     
    var xhr2 = getXhr();
     
    // On defini ce qu'on va faire quand on aura la reponse
    xhr2.onreadystatechange = function()
    {
    // On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    	if(xhr2.readyState == 4) {
    		leselect = xhr2.responseText;
    		// On se sert de innerHTML pour rajouter les options a la liste
    		document.getElementById('id_film').innerHTML = leselect
    	}
    }
     
    // Ici on va voir comment faire du post
    xhr2.open("POST","index.php?p=AjaxFilm",false);
    xhr2.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); 
    xhr2.send("id_acteur="+idcode);
    }

  3. #3
    Membre expérimenté Avatar de DoubleU
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 106
    Points : 1 388
    Points
    1 388
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    idcode = sel.options.selectedIndex.value;
    Tu peux faire encore plus simple:
    Bizarrement, cette syntaxe fonctionne dans ce contexte, alors que dans une fonction, elle ne fonctionne pas. Il faudrait demander pourquoi aux gurus du forum Javascript
    Parce que dans le onchange, le this représente le sélect, alors que dans la fonction, il représente la fonction elle même. Ceci étant, je ne sais pas si ca résoudra ton probleme.

    Dans le onchange (et pas onChange), tu peux enlever le javascript: qui ne sert a rien, on sait jamais.

  4. #4
    Membre régulier
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2004
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2004
    Messages : 105
    Points : 80
    Points
    80
    Par défaut
    Bonsoir à vous,

    Tout d'abord merci pour vos réponses

    J'ai donc passé toutes les valeurs en paramètre et tout fonctionne tranquillement

    Un grand merci à vos idées !!!

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 19/07/2010, 17h15
  2. [AJAX] tchatbox visible sous FF mais pas sous IE
    Par Jonathan.b dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 28/01/2008, 13h58
  3. [AJAX] Résultat de requête Ajax vide sous IE, mais pas sous FF
    Par brazilia28 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 14/09/2007, 16h18
  4. [AJAX] Ajax marche sous IE mais pas sous Firefox
    Par snoopy92 dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 10/05/2007, 18h24

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