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 :

'form' a la valeur null ou n'est pas un objet.


Sujet :

JavaScript

  1. #1
    Membre confirmé
    Inscrit en
    Décembre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Décembre 2008
    Messages : 72
    Par défaut 'form' a la valeur null ou n'est pas un objet.
    Bonjour à tous.
    J'ai besoin de votre aide pour résoudre un souci javascript.

    J'explique. Je veux ouvrir une nouvelle fenêtre(que j'appelle arbitrairement winPopup) à l'ouverture d'une première. L'ouverture épend aussi de la présence d'un document ou non.
    La première est constituée d'un form aussi que je ne veux pas soumettre.
    La winPopup ne sert en fait qu'à afficher le document s'il est présent.
    Je sais pas si je suis très clair ...

    Donc le code fonctionne très bien sous FireFox,, mais pas sous Ie7. C'est là mon problème, cela doit fonctionner sous Ie7.
    Le code erreur sous Ie7 est :
    'form' a la valeur null ou n'est pas un objet.

    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
     
    <form name="fdocument" ></form>
     
    <script>
     
     
    var winPopup;
     
    function openDocument(doc)  { 
      windowName = "Litige";
      form = document.forms['fdocument'];	
      form.action=doc; 
      form.target = windowName;
      form.submit(); 
      winPopup = window.open("", windowName); 
     
    }
     
    function closePopup() {  
      if (winPopup) winPopup.close();
    }
     
    var fileName ='chemin vers un document';
    if (!fileName == '') {
    	openDocument(fileName);
    }
    </script>

    Qu'en pensez-vous?
    Merci pour votre participation.

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Oui, dans la mesure où form est une propriété des éléments de formulaires, déjà, le nom de variable est mal choisi, mais si en plus tu ne précises pas qu'il s'agit d'une nouvelle variable... ça devient vraiment compliqué pour les navigateurs de s'adapter
    Essaye de changer de nom de variable et de préciser :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var form = document.forms['fdocument'];
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 658
    Billets dans le blog
    1
    Par défaut
    tu soumets le formulaire avant d'ouvrir la popup ...
    a mon avis un problème d'instanciation ...
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  4. #4
    Membre confirmé
    Inscrit en
    Décembre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Décembre 2008
    Messages : 72
    Par défaut
    Merci pour votre réactivité
    J'ai testé vos solutions mais cela ne fonctionne pas.
    Si je declare form en variable.
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    var form = document.forms['fdocument'];
    L'erreur devient 'undefined' est null etc...
    Sinon pour l'ouverture de la fenêtre avant la soumission du formulaire ca focntionne à moitié. La fenêtre s'ouvre mais vierge alors qu'elle devrait etre chargée.

  5. #5
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Bonjour,
    comme déjà dit, "form" est un très mauvais choix comme nom de variable

    Sinon, déplace ton passage <script> dans la partie <head> et appelle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    openDocument(fileName);
    sur l'évènement onload du <body>.

    Actuellement, ton form n'existe pas encore forcément à l'exécution de la fonction (d'où le message)

    A+

  6. #6
    Membre confirmé
    Inscrit en
    Décembre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Décembre 2008
    Messages : 72
    Par défaut
    Le nom de la variable n'est pas responsable du mauvais fonctionnement d'Ie7.
    J'ai déja changé le nom de la variable en plus de la déclarer mais cela ne change rien.
    Mon code s'intègre dans un autre ,je ne dois pas changer de structure.
    J'ai lu aussi sur internet que Ie avait du mal avec les document.forms et qu'il fallait les remplacer par des document.getElementsBy
    Mais même cette solution ne fonctionne pas.

  7. #7
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Mon code s'intègre dans un autre
    C'est sûr que ne pas donner l'ensemble des données d'un problème n'aide pas trop à le résoudre...
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  8. #8
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 658
    Billets dans le blog
    1
    Par défaut
    un setTimeout sur le sublit du form juste pour laisser le temps à la popup de s'instancier ...
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  9. #9
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Citation Envoyé par Bovino Voir le message
    C'est sûr que ne pas donner l'ensemble des données d'un problème n'aide pas trop à le résoudre...
    +1

    Il serait donc intéressant d'avoir l'ensemble de la page et du fonctionnement de celle-ci ...

    A+

  10. #10
    Membre confirmé
    Inscrit en
    Décembre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Décembre 2008
    Messages : 72
    Par défaut
    Je ne peux pas tout vous fournir je bosse pour une entreprise (qui elle-même bosse pour des clients qui ont "bien" payé ce développement)et je n'ai pas la permission de tout dévoiler. Je n'ai d'ailleurs aucune autorisation pour poster des bouts de code quels qu'ils soient.. J'en suis le premier désolé mais c'est comme ca.
    Pour ce qui est de la résolution du problème, je pense vous avoir fourni assez d'informations. Mon bout de code s'intègre dans un script. Donc autrement dit vous avez là toutes les données nécessaires à la compréhension de mon problème.Ne vous offusquez pas, mais je ne peux pas vous en fournir plus.
    En plus de ca je débute en javascript, et j'ai vraiment besoin de votre aide.

  11. #11
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Citation Envoyé par ruza01 Voir le message
    Donc autrement dit vous avez là toutes les données nécessaires à la compréhension de mon problème.Ne vous offusquez pas, mais je ne peux pas vous en fournir plus.
    Petite rectification :
    OK, tu n'as pas la possibilité de nous donner plus de code : c'est une contrainte et personne ne s'en "offusquera"
    Par contre, NON nous n'avons pas tous les éléments pour cerner ton problème.
    En l'état il est seulement possible de faire des suppositions (ce qui a été fait)

    A+

  12. #12
    Membre confirmé
    Inscrit en
    Décembre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Décembre 2008
    Messages : 72
    Par défaut
    Je vous assure toutes les données sont là. C'est un code qui se place dans un script. De plus mon souci est que je dois faire fonctionner ce code sous Ie7 alors que sous FF il fonctionne parfaitement.
    Pour la solution du setTimeout, je ne sais pas l'utiliser.Je l'ai placé ici
    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
     
    <form name="fdocument" ></form>
     
    <script>
     
     
    var winPopup;
     
    function openDocument(doc)  { 
      windowName = "Litige";
      form = document.forms['fdocument'];	
      form.action=doc; 
      form.target = windowName;
      setTimeout("submit()",10000);
      form.submit(); 
      winPopup = window.open("", windowName); 
     
    }
     
    function closePopup() {  
      if (winPopup) winPopup.close();
    }
     
    var fileName ='chemin vers un document';
    if (!fileName == '') {
    	openDocument(fileName);
    }
    </script>
    Mais ca ne change rien non plus.

  13. #13
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Citation Envoyé par ruza01 Voir le message
    Mais ca ne change rien non plus.
    Ben normal là tu fais quand même le submit immédiatement:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    setTimeout("submit()",10000);
    form.submit(); 
    A+

  14. #14
    Membre confirmé
    Inscrit en
    Décembre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Décembre 2008
    Messages : 72
    Par défaut
    J'ai sorti le setTimeout en dehors de la fonction openDocument et je remarque rien de particulier.

  15. #15
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Citation Envoyé par ruza01 Voir le message
    J'ai sorti le setTimeout en dehors de la fonction openDocument et je remarque rien de particulier.


    Oui, mais c'est pas ça le problème : il faut virer la ligne pour tester le setTimeout() ...

    A+

  16. #16
    Membre confirmé
    Inscrit en
    Décembre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Décembre 2008
    Messages : 72
    Par défaut
    Si je vire le submit(), le problème est à moitié résolu.
    J'ai bien une nouvelle fenêtre qui s'ouvre mais vierge alors qu'elle devrait être chargée.

  17. #17
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    J'ai bien une nouvelle fenêtre qui s'ouvre mais vierge alors qu'elle devrait être chargée.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    winPopup = window.open("", windowName);
    Non... pas vraiment !
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  18. #18
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Une question certainement bête : pourquoi tu ne fais pas plus simplement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    function openDocument(doc)  { 
      windowName = "Litige";
      winPopup = window.open(doc, windowName); 
    }


    A+

  19. #19
    Membre confirmé
    Inscrit en
    Décembre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Décembre 2008
    Messages : 72
    Par défaut
    Merci pour vos réponses.
    Le code fonctionne parfaitement sous FF comme cela. Il m'affiche bien une nouvelle fenêtre chargée et non vierge même si je ne donne pas d'url à ma nouvelle fenêtre.

    E.Bzz ta question n'est pas bête du tout mais très pertinente pusqu'elle solutionne mon problème lors de l'ouverture automatique de la fenêtre.
    Mais une fois fermée je dois pouvoir aussi l'appeler de nouveau, manuellement cette fois, grâce à un lien situé sur la première fenêtre, sans submiter la première fenêtre (qui est elle aussi dans un form)...
    D'où la nécéssité de passer par un form bidon (fdocument) et de lui donner toutes les info nécéssaire.

  20. #20
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Citation Envoyé par ruza01 Voir le message
    Mais une fois fermée je dois pouvoir aussi l'appeler de nouveau, manuellement cette fois, grâce à un lien situé sur la première fenêtre, sans submiter la première fenêtre (qui est elle aussi dans un form)...
    Ca peut se gérer aussi, ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function openDocument(doc)  { 
      windowName = "Litige";
      document.getElementById('lien_pop').href = doc;
      document.getElementById('lien_pop').target = "Litige"    // Pour éviter de l'ouvrir 2 fois si elle est déjà ouverte
      winPopup = window.open(doc, windowName); 
    }
    avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a id="lien_pop" href="">Réouvrir la pop</a>
    en l'adaptant bien sûr à ton lien actuel ...

    A+

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Erreur sous IE : 'form' a la valeur Null ou n'est pas un objet
    Par Esil2008 dans le forum Général JavaScript
    Réponses: 10
    Dernier message: 30/04/2008, 16h39
  2. [DOM] Erreur JS (valeur null ou n'est pas un objet)
    Par jibeji dans le forum Général JavaScript
    Réponses: 13
    Dernier message: 10/02/2008, 15h42
  3. Réponses: 1
    Dernier message: 22/05/2007, 12h51
  4. 'value' a la valeur Null ou n'est pas un objet
    Par FrankOVD dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 31/05/2006, 08h25

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