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 :

passer des variables d'un script à un autre


Sujet :

JavaScript

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    423
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 423
    Points : 133
    Points
    133
    Par défaut passer des variables d'un script à un autre
    Bonjour,

    dans ma page web, j'ai un script déclaré dans l'en-tête, et qui s'exécute au chargement de la page.
    dans ce script, je déclare un variable utilisée pour créer une carte dans la page.

    puis, dans la page, j'ai un autre script qui doit utiliser cette variable, comment faire pour la transmettre au deuxième script ?

    Merci,

    Nico

  2. #2
    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 638
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 638
    Points : 66 667
    Points
    66 667
    Billets dans le blog
    1
    Par défaut
    une variable est rattachée à la page html ...
    elle est accessible depuis tout script sur la page en fonction de sa portée.
    Pour peu qu'elle soit globale elle sera accessible partout
    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 !

  3. #3
    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 : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Il suffit de la déclarer comme propriété de l'objet window :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function fonction1(){
        window.toto = 'test';
    }
    function fonction2(){
        alert(window.toto);
    }
    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

  4. #4
    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 638
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 638
    Points : 66 667
    Points
    66 667
    Billets dans le blog
    1
    Par défaut
    Beef il a dit variable dans script ... pas dans fonction

    Mais il s'agit en effet vraisemblablement d'une question de portée
    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 !

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    423
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 423
    Points : 133
    Points
    133
    Par défaut
    justement, j'ai bien déclaré ma variable map en globale, voici mon code :
    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    <html>
    <head>
    <link rel="icon" type="image/gif" href="img/favicon.gif" /><style type="text/css"><!-- @import url(css/observatoire.css); --></style>
    <style type="text/css"><!-- @import url(css/menu.css); --></style>
    <style type="text/css"><!-- @import url(css/formulaire.css); --></style>
    <script  type="text/javascript" src="js/mm_menu.js"> </script>
    <script  type="text/javascript" src="js/menu.js"> </script>
    <script  type="text/javascript" src="js/hydrophones.js"> </script>
     
    <script  type="text/javascript" src="lib/OpenLayers-2.8/OpenLayers.js"> </script>
    <script type="text/javascript" src="http://maps.google.com/maps?file=api&amp;v=2&amp;key=ABQIAAAA_MdnJvro6Af_kBpPj91YchTFUzj6dbs8BxywBtmpjnpJAxlULBQMuM4A5wkDXhgk_jiEZ8DOzxkpGA&sensor=true"></script>
    <script  type="text/javascript" src="js/calendrier/dhtmlgoodies_calendar.js?random=20060118"> </script>
    <link type="text/css" rel="stylesheet" href="js/calendrier/dhtmlgoodies_calendar.css?random=20051112" media="screen"></link>
     
    <script type="text/javascript">
    var map, seismesLayer;
    function init(){
    var mapOptions = {
    			controls:[new OpenLayers.Control.MouseDefaults()],
    			projection: new OpenLayers.Projection("EPSG:900913"),
    			displayProjection: new OpenLayers.Projection("EPSG:4326"),
    			units: "m",
    		        numZoomLevels: 18,
    		        maxResolution: 156543.0339,
    		        maxExtent: new OpenLayers.Bounds(-20037508, -20037508, 20037508, 20037508.34) 
    			};
    map = new OpenLayers.Map('map', mapOptions);
    var styleSeismes = new OpenLayers.StyleMap({
    				"default": new OpenLayers.Style({
    							pointRadius: 4,
    							graphicName: "square",
    							fillColor: "white",
    							fillOpacity: 1,
    							strokeWidth: 1,
    							strokeOpacity: 1,
    							strokeColor: "#333333"
    							})
    			});
    var g_satellite = new OpenLayers.Layer.Google("Google Satellite", {
    							type: G_SATELLITE_MAP,
    							'sphericalMercator': true}
    							);
    map.addLayers([g_satellite]);
    seismesLayer = new OpenLayers.Layer.Vector('Seismes', {styleMap: styleSeismes});
    map.addLayers([seismesLayer]);
    map.zoomTo(2);
    }
    </script>
     
    </head>
    <body class="body" onload="init()">
    ......
    puis, dans ma page, dans une section php :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<script>majCarto(map.getLayersByName(\'Seismes\'),\''.$s.'\')</script>';
    où la fonction majCarto est déclarée dans hydrophones.js

    dans la console d'erreur FireFox, j'ai une erreur :
    'map is undefined'

    Nico

  6. #6
    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 638
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 638
    Points : 66 667
    Points
    66 667
    Billets dans le blog
    1
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <script type="text/javascript">
    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 !

  7. #7
    Inactif
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 63
    Points : 81
    Points
    81
    Par défaut
    Citation Envoyé par DiverSIG Voir le message
    justement, j'ai bien déclaré ma variable map en globale, voici mon code :
    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    <html>
    <head>
    <link rel="icon" type="image/gif" href="img/favicon.gif" /><style type="text/css"><!-- @import url(css/observatoire.css); --></style>
    <style type="text/css"><!-- @import url(css/menu.css); --></style>
    <style type="text/css"><!-- @import url(css/formulaire.css); --></style>
    <script  type="text/javascript" src="js/mm_menu.js"> </script>
    <script  type="text/javascript" src="js/menu.js"> </script>
    <script  type="text/javascript" src="js/hydrophones.js"> </script>
     
    <script  type="text/javascript" src="lib/OpenLayers-2.8/OpenLayers.js"> </script>
    <script type="text/javascript" src="http://maps.google.com/maps?file=api&amp;v=2&amp;key=ABQIAAAA_MdnJvro6Af_kBpPj91YchTFUzj6dbs8BxywBtmpjnpJAxlULBQMuM4A5wkDXhgk_jiEZ8DOzxkpGA&sensor=true"></script>
    <script  type="text/javascript" src="js/calendrier/dhtmlgoodies_calendar.js?random=20060118"> </script>
    <link type="text/css" rel="stylesheet" href="js/calendrier/dhtmlgoodies_calendar.css?random=20051112" media="screen"></link>
     
    <script type="text/javascript">
    var map, seismesLayer;
    function init(){
    var mapOptions = {
    			controls:[new OpenLayers.Control.MouseDefaults()],
    			projection: new OpenLayers.Projection("EPSG:900913"),
    			displayProjection: new OpenLayers.Projection("EPSG:4326"),
    			units: "m",
    		        numZoomLevels: 18,
    		        maxResolution: 156543.0339,
    		        maxExtent: new OpenLayers.Bounds(-20037508, -20037508, 20037508, 20037508.34) 
    			};
    map = new OpenLayers.Map('map', mapOptions);
    var styleSeismes = new OpenLayers.StyleMap({
    				"default": new OpenLayers.Style({
    							pointRadius: 4,
    							graphicName: "square",
    							fillColor: "white",
    							fillOpacity: 1,
    							strokeWidth: 1,
    							strokeOpacity: 1,
    							strokeColor: "#333333"
    							})
    			});
    var g_satellite = new OpenLayers.Layer.Google("Google Satellite", {
    							type: G_SATELLITE_MAP,
    							'sphericalMercator': true}
    							);
    map.addLayers([g_satellite]);
    seismesLayer = new OpenLayers.Layer.Vector('Seismes', {styleMap: styleSeismes});
    map.addLayers([seismesLayer]);
    map.zoomTo(2);
    }
    </script>
     
    </head>
    <body class="body" onload="init()">
    ......
    puis, dans ma page, dans une section php :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<script>majCarto(map.getLayersByName(\'Seismes\'),\''.$s.'\')</script>';
    où la fonction majCarto est déclarée dans hydrophones.js

    dans la console d'erreur FireFox, j'ai une erreur :
    'map is undefined'

    Nico
    ta fonction init ne s'execute que sur le onload.

    En gros on a cette ordre là :
    déclaration map => map == null
    appel majCarto => echo '<script>majCarto(map.getLayersByName(\'Seismes\'),\''.$s.'\')</script>';
    - page chargée
    - lancement de init()
    - initialisation de map.

    Donc le constat est simple, ya un problème de conception.
    Tu ferais mieux de lancer majCarto sur le onload aussi. Mais après tu auras peut etre du code à changer j'en sais rien.

Discussions similaires

  1. [PHP 5.4] Peut-on passer des variables en GET d'un script à un autre?
    Par moreall dans le forum Langage
    Réponses: 13
    Dernier message: 02/02/2015, 12h56
  2. Passer des variables d'un fichier à l'autre
    Par methodman225 dans le forum Langage
    Réponses: 2
    Dernier message: 16/12/2007, 14h22
  3. Passer des variables a une autre page
    Par Bydouille dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 16/10/2007, 22h59
  4. Passer des variables d'une form à l'autre
    Par flydan dans le forum Débuter
    Réponses: 3
    Dernier message: 11/10/2007, 13h19
  5. [débutant]Passer des variables d'une page à une autre
    Par MayOL69bg dans le forum ASP.NET
    Réponses: 1
    Dernier message: 14/03/2007, 10h53

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