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 :

accéder au body d'un frame à partir d'un autre frame


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Janvier 2008
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations forums :
    Inscription : Janvier 2008
    Messages : 57
    Points : 39
    Points
    39
    Par défaut accéder au body d'un frame à partir d'un autre frame
    Bonjour;
    j'ai dans ma page 3 frames
    je veux accéder à partir du frame 1 au body du frame 2 pour y insérer un texte.
    J'ai pas réussi à trouver la bonne syntaxe.
    Quelqu'un a une idée?
    Merci pur tout aide.

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Regarde la FAQ, mais au lieu d'utiliser la propriété location, tu utiliseras body.

    A+.

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Janvier 2008
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations forums :
    Inscription : Janvier 2008
    Messages : 57
    Points : 39
    Points
    39
    Par défaut
    Bonjour,

    parent.frames['contenu'].body génère l'erreur suivante :

    Erreur : parent.frames.contenu.body is undefined

  4. #4
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Ton frame a un name="contenu"?
    Peut-on voir ton code html?

    A+.

  5. #5
    Membre émérite
    Avatar de Eric2a
    Homme Profil pro
    Technicien
    Inscrit en
    Septembre 2005
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Technicien

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 225
    Points : 2 411
    Points
    2 411
    Par défaut
    Salut,

    Oui, pour accéder à la balise iframe , il faut lui ajouter l'attribut name ou id.

    Dans l'exemple ci-dessous, l'attribut id (ayant pour valeur ifrm2) est utilisé.

    index.html
    Page contenant les cadres
    Code xhtml : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    	<head>
    		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    		<title>Index</title>
    	</head>
    	<body>
    		<iframe src="iframe-1.html"></iframe>
    		<iframe src="iframe-2.html" id="ifrm2"></iframe>
    	</body>
    </html>

    iframe-1.html
    Premier cadre
    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
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    	<head>
    		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    		<title>iframe 1</title>
    		<script type="text/javascript">//<![CDATA[
    			function appendText(){
    				var
    					ifr,body,div;
     
    				// ifr = Balise du deuxième cadre (id='ifrm2') du document parent
    				ifr=window.top.document.getElementById('ifrm2');
    				if(!ifr)return alert('Deuxième cadre non trouvé');
     
    				// body = Balise body du cadre
    				if(ifr.contentDocument)
    					body=ifr.contentDocument.getElementsByTagName('body')[0];
    				else if(ifr.contentWindow) // IE
    					body=contentWindow.document.getElementsByTagName('body')[0];
     
    				// Ajout du nouveau contenu dans le deuxième cadre
    				div=document.createElement('div');
    				div.appendChild(document.createTextNode('Voici le texte ajouté'));
    				body.appendChild(div);
    			}
    			//]]>
    		</script>
    	</head>
    	<body>
    		<p><button onclick="appendText();">Ajouter</button></p>
    	</body>
    </html>

    iframe-2.html
    Deuxième cadre (vide pour l'exemple)
    Code xhtml : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    	<head>
    		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    		<title>iframe 2</title>
    	</head>
    	<body>
    	</body>
    </html>

    À voir également postMessage

  6. #6
    Membre expérimenté Avatar de Willpower
    Homme Profil pro
    sans emploi
    Inscrit en
    Décembre 2010
    Messages
    1 009
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : sans emploi

    Informations forums :
    Inscription : Décembre 2010
    Messages : 1 009
    Points : 1 519
    Points
    1 519
    Par défaut
    à noter également que si les frames appartiennent à des domaines(sites) différents, elles n'auront pas accès entre-elles.

    (execpté via postMessage comme l'a suggeré eric2a)
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    eval(a='eval(a)')
    recursive make it evil
    eval make it eval

Discussions similaires

  1. Réponses: 5
    Dernier message: 27/07/2011, 16h56
  2. appel d'une autre frame à partir d'une autre classe
    Par oceane751 dans le forum AWT/Swing
    Réponses: 18
    Dernier message: 19/01/2008, 06h41
  3. mise à jour d'une frame à partir d'une autre frame
    Par youness78 dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 09/07/2007, 14h58
  4. Réponses: 6
    Dernier message: 27/10/2005, 21h12
  5. Rafraichissement d'une frame à partir d'une autre
    Par VinceTlse dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 12/08/2005, 11h18

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