Curs Javascript

In acest tutorial este prezentat modul de preluarea si modificare a continutului unui IFRAME, din pagina principala, folosind JavaScript.
Este important de mentionat ca pagina care este inclusa in IFrame trebuie sa se afle pe acelasi server cu pagina principala, altfel nu va fubnctiona din motive de securitate.

Trecand direct la subiect, pentru a prelua si modifica continutul dintr-un IFrame, se poate folosi proprietatea ""contentWindow, aceasta returneaza obiectul "window" al unui frame sau iframe specificat.
Iata un exemplu din care se poate intelege modul de aplicare al acestei proprietati.

1. Cream intai un fisier "ifr.htm" ce va contine codul HTML al paginii ce va fi afisata in IFrame.

Cod ifr.htm

<html>
<head><title>Pagina iframe</title></head>
<body>
Continut din IFrame.<br />
Continuare continut ...
</body>
</html>

2. Definim si pagina principala, de exemplu "main.html" (in acelasi director pe server), in care scriem codul penru includerea IRame-ului si scriptul JavaScript care va prelua si modifica continutul din IFrame.
- Explicatiile necesare le gasiti in codul script-ului.

Cod main.html

<html>
<head><title>Pagina principala</title></head>
<body>
<script type="text/javascript">
function get_iframe(ifr_id) {
    // Preia obiectul ce face referire la iframe, dupa id-ul acestuia
    var myIFrame = document.getElementById(ifr_id);

    // Se aplica proprietatea "contentWindow" la obiectul-ul iframe-ului
    // Astfel se preia fereastra acestuia si cu celelalte proprietati continutul din el
    var content = myIFrame.contentWindow.document.body.innerHTML;

alert("Content: \n" + content);                 // Afiseaza o fereastra Alert cu datele preluate

    // Se defineste un text HTML nou care va inlocui continutul din iframe
    content = '<font color="blue">Text adaugat prin JavaScript, din pagina principala</font>';

    // Se aplica modificarea continutului
    myIFrame.contentWindow.document.body.innerHTML = content;
}
</script>

<h3>Pagina principala</h3>
<a href="#" onclick="get_iframe('ifr')">Preia /Modifica IFrame</a><br><br>
<iframe src="ifr.htm" id="ifr" name="ifr"></iframe>
</body>
</html>

- Acest exemplu va afisa urmatorul rezultat:

Pagina Principala

Preia /Modifica IFrame

Continut din IFrame.
Continuare continut ...

- Cand dati click pe link-ul "Preia /Modifica IFrame", va fi apelata functia "get_iframe()", care preia si afiseaza intr-o fereastra Alert continutul din IFrame, apoi seteaza un alt continut si-l inlocueste. Daca darti cluck inca o data, i-l va prelua si afsa pe cel inlocuit.

O alta metoda ce ar putea fi folosita, in loc de "contentWindow", este proprietatea "parent" impreuna cu numele IFrame-ului. Cu aceasta pot fi preluate si valori de variabile JS aflate in IFrame si chiar apela functii JavaScript aflate in el.
Aceasta metoda este prezentata in tutorialul urmator, in care este aratat modul de preluare si modificare a continutului unui IFrame printr-un script JS ce se afla intr-un al doilea IFrame.

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Care meta tag se foloseste pentru scurta descriere a paginii?
<meta content="..."> <meta description="..."> <meta http-equiv="...">
<meta name="description" content="70-160 caractere ce descriu continutul paginii" />
Ce proprietate CSS opreste efectul dat de "float"?
clear text-align position
#some_id {
  clear: both;
}
Clic pe metoda ce creaza un array cu toate elementele din pagina cu un anumit nume de tag.
getElementsByName() getElementById() getElementsByTagName()
var divs = document.getElementsByTagName("div");
var nr_divs = divs.length;
alert(nr_divs);
Indicati functia PHP ce returneaza numarul de elemente dintr-un array.
is_[) count() strlen()
$arr =[7, 8, "abc", 10);
$nri = count($arr);
echo $nri;        // 4
Indicati adverbul corespunzator adjectivului din paranteza in propozitia: "I live (happy)".
happly happily hapily
I live happily.
- Traiesc fericit (in mod fericit).
Indicati adverbul corespunzator adjectivului din paranteza in propozitia: "Vivo (feliz)".
felizamente felizmente felices
Vivo felizmente.
- Traiesc fericit (cu fericire).
Preluare si modificare continut IFrame

Last accessed pages

  1. Creare si editare pagini HTML (86140)
  2. Adverbele in limba engleza - Adverbs (33440)
  3. Trecut nedefinit vs imperfect (559)
  4. Instructiuni repetitive for si while (5751)
  5. Verbe care schimba baza: o:ue (2334)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (935)
  2. Coduri pt culori (787)
  3. Curs HTML gratuit Tutoriale HTML5 (675)
  4. Cursuri limba engleza gratuite si lectii online (295)
  5. Exercitii engleza - English Tests and exercises - Grammar (289)