Curs Javascript

In aceasta lectie puteti invata cum se pot accesa mai multe metode inlantuite in JavaScript.
Inlantuirea metodelor inseamna accesarea mai multor metode, sau functii ale unui obiect, intr-o singura instructune.

obiect.metoda_1().metoda_2()
Cerinta prin care se pot accesa metode inlantuite este ca metodele (functiile) sa fie definite folosind cuvantul special this (ca sa poata fi accesate in exterior), iar metoda precedenta (aici metoda_1() ) sa returneze instanta de obiect.
• Sintaxa:
var NumeClasa = function() {
 var thisob = this; // retine instanta de obiect

 this.metoda_1 = function(){
 // un cod JavaScript

 return thisob; // returneaza instanta de obiect
 }

 this.metoda_2 = function(){
 // instructiuni JavaScript
 }
}
- Iata un exemplu, un obiect JavaScript prin care se pot calcula aria si perimetrul dreptunghiului (vedeti comentariile din cod si testati-l).
<script>
var Rectangle = function() {
 var thisob = this; // retine instanta de obiect
 var a = 0;
 var b = 0;

 // seteaza valorile pt. a si b
 this.setAB = function(a1, b1){
 a = a1;
 b = b1;

 return thisob; // returneaza instanta de obiect
 }

 // returneaza aria
 this.area = function(){
 return a * b;
 }

 // returneaza perimetru
 this.perimeter = function(){
 return 2 * (a + b);
 }
}

// creaza o instanta de obiect a clasei
var obR = new Rectangle();

// seteaza valorile laturilor si obtine aria si perimetru
var area = obR.setAB(7, 8).area();
var perimeter = obR.setAB(7, 8).perimeter();

// test
alert('Aria = '+ area +'\nPerimetru = '+ perimeter);
</script>

• Se pot apela mai mult de doua metode inlantuite, tehnica e aceeasi, metodele sa fie definute folosind cuvantul "this", si toate metodele accesate precedent trebuie sa returneze instanta de obiect.
- Iata un exemplu de inlantuire trei metode. Un obiect JavaScript ce poate crea un tag HTML, cu ID, atribut "class" si continut (studiati codul si testati-l).
<script>
var setTag = function() {
 var thisob = this; // retine instanta de obiect
 var id = ''; // atributul id
 var cls = ''; // atributul class

 // seteaza id-ul
 this.setId = function(id1){
 id = ' id="'+ id1 +'"';

 return thisob; // returneaza instanta de obiect
 }

 // seteaza atributul class
 this.setClass = function(cls1){
 cls = ' class="'+ cls1 +'"';

 return thisob; // returneaza instanta de obiect
 }

 // returneaza tag-ul HTML si continutul
 this.getTagCnt = function(tag, cnt){
 return '<'+ tag + id + cls +'>'+ cnt +'</'+ tag+ '>';
 }
}

// creaza o instanta de obiect a clasei
var obTag = new setTag();

// variabile cu tipul tag-ului si continut
var tag = 'div';
var cnt = 'https://marplo.net';

// apeleaza metodele inlantuite pt. setare ID, "class", si obtine un <div> cu aceste atribute si continut
var getTag = obTag.setId('some_id').setClass('a_class').getTagCnt(tag, cnt);

// test
alert(getTag); // <div id="some_id" class="a_class">https://marplo.net</div>
</script>
Instructiunea cu metodele inlantuite din codul de mai sus:
var getTag = obTag.setId('some_id').setClass('a_class').getTagCnt(tag, cnt);
E la fel cu acest cod:
// seteaza pe rand ID-ul, "class", apoi obtine tag-ul cu continutul
obTag.setId('some_id');
obTag.setClass('a_class');
var getTag = obTag.getTagCnt(tag, cnt);

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Ce element HTML adauga continut flash SWF in pagina web?
<object> <div> <script>
<object type="application/x-shockwave-flash" data="file.swf" width="500" height="250">
 <param name="src" value="file.swf" />
 Browser-ul dv. nu suporta SWF.
</object>
Care pseudo-clasa CSS adauga un stil la un camp input de formular cand e cursorul in el?
:active :focus :hover
input:focus {
  background-color: #88fe88;
}
Clic pe instructiunea care transforma un sir JSON in obiect JavaScript.
JSON.stringify(javascript_object) object.toString() JSON.parse(json_string)
var jsnstr = '{"url": "http://coursesweb.net/", "title": "Web Development Courses"}';
var obj = JSON.parse(jsnstr);
alert(obj.url);
Indicati functia PHP care poate crea sau scrie un fisier pe server.
fopen() file_put_contents() file_get_contents()
if (file_put_contents("file.txt", "content")) echo "Fisierul a fost creat";
else echo "Fisierul nu poate fi creat";
Cum se spune "al treilea" in engleza?
threeth third three
I planted the third tree.
- Am plantat al treilea pom.
Cum se spune "al treilea" in spaniola?
segundo tres tercero
Yo planté el tercero árbol.
- Am plantat al treilea pom.
Inlantuire mai multe metode de obiect in JavaScript

Last accessed pages

  1. Prepozitii: A, con, de sau en 1 (1147)
  2. Proverbe, expresii si zicatori (24704)
  3. Verbe neregulate (5583)
  4. Prefixele dis-, mis-, un-. The DIS, MIS and UN prefixes (12224)
  5. Adverbele in limba engleza - Adverbs (33510)

Popular pages this month

  1. Curs HTML gratuit Tutoriale HTML5 (557)
  2. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (537)
  3. Coduri pt culori (339)
  4. Creare si editare pagini HTML (189)
  5. Formatare text in pagina html (182)