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.
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.
Bonjour,
Regarde la FAQ, mais au lieu d'utiliser la propriété location, tu utiliseras body.
A+.
Bonjour,
parent.frames['contenu'].body génère l'erreur suivante :
Erreur : parent.frames.contenu.body is undefined
Ton frame a un name="contenu"?
Peut-on voir ton code html?
A+.
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
à 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)
Partager