login  Naam:   Wachtwoord: 
Registreer je!
 Tutorials

Tutorials > Javascript


Gegevens:
Geschreven door:
nemesiskoen
Moeilijkheidsgraad:
Gemakkelijk
Hits:
10020
Punten:
Aantal punten:
 (3.5)
Aantal stemmen:
6
Stem:
Niet ingelogd
Nota's:
 Lees de nota's (2)
 

Tutorial:

Objecten, properties en prototypes

1. Inleiding
2. Properties van een object
3. Object aanmaken: object-initializer
4. Object aanmaken: constructor
5. HTML objecten aanmaken
6. Prototypes
 top
1. Inleiding
In javascript is het mogelijk je eigen objecten te maken.
Deze objecten kunnen data en methodes bevatten.
Deze data (die in 'lid-variabelen' steekt) en deze methodes (ook wel functies genaamd) noemt men de 'properties' van het object.
Een object is een soort blauwdruk waarin, als je het goed doet, duidelijk word beschreven 'wat het doet'.
Dit klinkt op het begin nogal ingewikkeld maar eigenlijk valt het goed mee.

 top
2. Properties van een object

De properties, waar ik het daarnet over had, kunnen worden aangeroepen op een heel simpele manier.
naam_van_het_object.naam_van_de_property

Maar voor dat je ze kan aanroepen moet je ze eerst 'aan maken'.
Hier zijn 2 manieren voor:
1) een object-initializer gebruiken.
2) een constructor maken.

 top
3. Object aanmaken: object-initializer

Als je maar 1 object van 1 soort wil maken is de object-initializer erg handig, voor meerdere objecten is het handig om de constructor-methode te gebruiken.

De objet-initializer werkt als volgt:
naam_van_het_object = {property1 : waarde1, property2 : waarde2, ...}
// je kan ook een object binnen een object aanmaken:
object1 = {property1 : waarde1, object2 : {property2.1 : waarde2.1, property2.2 : waarde2.2,...},...}

Dit ziet er allemaal ingewikkeld uit, maar ik ga even een klein voorbeeldje geven waardoor dit allemaal wat duidelijker word.
nemesiskoen = {naam : 'koen', leeftijd : '17', haar : {kleur : 'bruin', lengte : 'lang', gewassen : true}}
alert(nemesiskoen.naam);
alert(nemesiskoen.haar.kleur);
// output : 'koen', 'bruin'

// je kan heel gemakelijk nieuwe property's toevoegen:
nemesiskoen.heeft_computer = true;
nemesiskoen.computer = {geheugen : '...', videokaart : '...', ...};
// enz

Nu zie je waarschijnlijk hoe handig objecten kunnen zijn.
Toch, als je bv. voor elk personage een nieuw object moet gaan aanmaken en telkens zeggen welke property's er zijn en dan pas de waarde in stellen, dan ga je veel tijd verliezen.
Hier is een handige oplossing voor, namelijk via de constructor methode.
 top
4. Object aanmaken: constructor

Je maakt een functie aan, die als constructor dient en hierin initializeer je alle property's.
function mens(naamleeftijd) {
this.naam naam;
this.leeftijd leeftijd;
}

nemesiskoen = new mens('koen'17);
vintage = new mens('ralph'36);
murfy = new mens('maarten'16);

alert(murfy.naam);
alert(nemesiskoen.leeftijd);
alert(vintage.naam);


Stel we willen murfy een nieuwe property geven, namelijk de 'heeft_computer' property.
Dan kunnen we simpel de syntax gebruiken die we hierboven ook hebben gebruikt.
function mens(naamleeftijd) {
this.naam naam;
this.leeftijd leeftijd;
}

murfy = new mens('maarten'16);

murfy.heeftComputer true;

if(
murfy.heeftComputer)
    
alert(murfy.naam ' heef een computer');
else
    
alert(murfy.naam ' heeft geen computer');


Nu is er nog een leuk mogelijkheid bij objecten, en dit is namelijk objecten binnen objecten.
Hetgeen ik daarnet al heb aangetoond met de 'computer' binnen het object 'nemesiskoen'.
Dit gaat ook via een constructor.
function auto(merkbouwjaar) {
    
this.merk merk;
    
this.bouwjaar bouwjaar;
}
function 
mens(naamleeftijdauto) {
    
this.naam naam;
    
this.leeftijd leeftijd;
    
this.auto auto;
}

z3 = new auto('BMW'1998);
murfy = new mens('maarten'16z3);

alert(murfy.auto.merk);

Ik hoop dat je nu begint te zien hoe fijn het werken met objecten binnen javascript is.
Nu kunnen we alles nog een stapje verder zetten en methodes (functies) aan het object gaan toevoegen.
function getNaam() {
    
alert(this.naam);
}
function 
getLeeftijd(leeftijd) {
    
alert(this.leeftijd);
}
function 
mens(naamleeftijd) {
    
this.naam naam;
    
this.leeftijd leeftijd;
    
this.getNaam getNaam;
    
this.getLeeftijd getLeeftijd;
}
fangorn = new mens('thomas'26);
fangorn.getLeeftijd();

 top
5. HTML objecten aanmaken

Zoals je misschien wel weet kent HTML ook objecten.
Deze hebben ook properties, attributen genaamd.
Een voorbeeld.
<input type="text" name="foo" value="bar" />

Hier zie je het object input met de properties 'type', 'name' en 'value'.
In het echt heeft input er nog meer (id, class, ...) maar we zullen ons beperken tot deze 3.
Nu kan je het maken van deze 'velden' automatiseren via javascript.
Namelijk door zelf een object input aan te maken en deze waardes in te stellen.
We beginnen met de constructor.
function input(typenamevalue) {
this.type type;
this.name name;
this.value value;
}

Hiermee kunnen we de volgende objecten mee aanmaken.
pass = new input('password''pass''***');

naam = new input('text''naam''');

Nu hebben we een input van het type 'password' en van het type 'text'.
Maar eigenlijk hebben we hier niets aan, omdat er niets op het scherm komt.
Dat kunnen we oplossen door een functie hier aan vast te maken.
Namelijk 'printinput()'.
function printinput() {
document.write('<input type="'this.type +'" name = "'this.name +'" value = "'this.value +'">');
}

En om af te sluiten moeten we dit koppelen aan het object, en de functie aanroepen.
function printinput() {
document.write('<input type="'this.type +'" name = "'this.name +'" value = "'this.value +'">');
}

function 
input(typenamevalue) {
this.type type;
this.name name;
this.value value;
this.printinput printinput;
}

pass = new input('password''pass''***');

naam = new input('text''naam''');

pass.printinput();
naam.printinput();

Nu zouden we kunnen automatiseren door het printen automatisch te laten verlopen.
We laten printen binnen de constructor.
function input(typenamevalue) {
this.type type;
this.name name;
this.value value;
document.write('<input type="'this.type +'" name = "'this.name +'" value = "'this.value +'">');
}

pass = new input('password''pass''***');

naam = new input('text''naam''');

En zo kan je nog op honderden andere manieren automatiseren.
 top
6. Prototypes

Buiten het aanmaken en manipuleren van objecten is het ook mogelijk deze te extenden.
Dit betekend dat je de constructor van het object alle eigenschappen van de constructor van een ander object laat 'overerven' zodat het deze ook heeft.
Zo kun je onderscheid maken tussen verschillende 'groepen' binnen 1 object.
Bv. voertuig.
Dit kan opgesplitst worden in vliegtuigen, rijtuigen en vaartuigen. Deze kunnen op hun beert weer opgesplitst worden, en zo kan je blijven doorgaan.
Hierdoor maak je een soort van hiėrarchie.
In javascript word een object waaruit een ander object word afgeleid een 'prototype' genoemd.
Een soort van 1e versie die nog kan 'verbeterd' en 'uitgebreid' worden.
Om te beginnen ga ik eerst laten zien hoe je zo'n prototype aanmaakt en een ander object hieruit afleid.
function voertuig() {
    
this.beweegt false// het staat stil
    
this.soort "geen soort"// kan nog worden ingevuld
}

function 
rijtuig() {
    
this.heeft_wielen true;
}

rijtuig.prototype = new voertuig;

auto = new rijtuig;

if(
auto.beweegt)
    
alert('Vroem!');
else
    
alert('auto staat stil');
    
// we gaan de auto laten bewegen

auto.beweegt true;

if(
auto.beweegt)
    
alert('Vroem!');
else
    
alert('auto staat stil');


Nu kan je een klein trukje uithalen met auto, namelijk deze meegeven als argument met een functie speciaal hiervoor ontworpen.
Dit toon ik in onderstaand voorbeeld.
function print_beweging(wattekst) {
    if(
wat.beweegt)
        
alert(tekst);
    else
        
alert(wat.soort +' beweegt niet');
}

auto = new rijtuig;
auto.soort 'auto';

print_beweging(auto'Vroem!');


Nu is dit maar een kleinigheidje vergeleken met wat je allemaal kan doen met 'extenden'.
Onderstaand voorbeeld laat zien hoe je een 'property' kunt toevoegen aan een 'prototype' van een bepaalde 'constructor'.
Bovenstaande zin klinkt misschien moeilijk, maar dit wil hetzelfde zeggen als: we geven het object rijtuig een nieuwe property via auto.
rijtuig.prototype.heeft_wielen false// standaard waarde is false
auto.heeft_wielen true// een auto heeft wielen;)

boot = new voertuig;
boot.soort "boot";

if(
boot.heeft_wielen)
    
alert('Vroem met de boot?');
else
    
alert('Boot heeft geen wielen');
    

Een andere handigheid is dat je 'flexibele' constructors kan maken.
Zodat je kan kiezen of je een argument meegeeft of niet.
Je kan dus kiezen of je een naam geeft aan het voertuig of niet.
function voertuig(naambeweegt) {
    
this.naam naam || "geen naam";
    
this.beweegt beweegt || false;
}

boot1 = new voertuig('Speedboot');
boot2 = new voertuig;

boot2.beweegt true;

/*
boot1 ziet er zo uit:
boot1.naam == 'Speedboot'
boot1.beweegt == false

boot2 ziet er zo uit:
boot2.naam == 'geen naam';
boot2.beweegt == true
*/

En het in beweging zetten kunnen we natuurlijk ook automatiseren.
function beweeg() {
    
this.beweegt true;
}

function 
stop() {
    
this.beweegt false;
}

function 
printBeweeg() {
    if(
this.beweegt)
        
alert('Beweging!');
    else
        
alert('Staat stil!');
}

function 
voertuig(naambeweegt) {
    
this.naam naam || "geen naam";
    
this.beweegt beweegt || false;
    
this.beweeg beweeg;
    
this.stop stop;
    
this.printBeweeg printBeweeg;
}

boot = new voertuig('Speedboot'true);
boot.printBeweeg();
boot.stop();
boot.printBeweeg();
boot.beweeg();
boot.printBeweeg();


Zoals je kan zien heb ik drie methodes aan de constructor gekoppeld: stop, beweeg en printBeweeg.
De eerste laat het voertuig stoppen, de tweede zet het in gang en de derde laat op het scherm weergeven 'wat' er gebeurt (bewegen of stil staan).
Nu kunnen we dit allemaal nog een stapje verderzetten en de 'richting' dat het voertuig beweegt aangeven, de snelheid en nog veel veel meer.
Beide eigenschappen horen bij voertuig, hoewel bij het printen je de methode beter los kan koppelen van elkaar.
De snelheid van de boot is immers in knopen en die van auto in km/h.
Hier een laatste voorbeeld om te laten zien hoe ver je dit kan trekken.
/*
    DE HOOFDCONSTRUCTOR EN ZIJN METHODES
*/

function printBeweeg(special) {
    if(
this.beweegt)
        
alert(special || 'Beweging!');
    else
        
alert('Staat stil!');
}

function 
setSnelheid(hoeveel) {
    if(
hoeveel 0) {
        
this.beweegt true;
        
this.snelheid hoeveel;
    } else {
        
this.beweegt false;
        
this.snelheid false;
    }
}

function 
voertuig() {
    
this.stop stop;
    
this.printBeweeg printBeweeg;
    
this.setSnelheid setSnelheid;
    
// richting
    // setrichting
    // ...
    // zo zijn er nog zoveel voorbeelden
}

/*
    DE SUBCONSTRUCTORS EN HUN METHODES
*/

function printRijSnelheid() {
    if(
this.beweegt && this.snelheid != 0)
        
alert(this.naam +" beweegt met een snelheid van "this.snelheid " km/h");
    else
        
alert(this.naam +" beweegt niet");
}
function 
printVaarSnelheid() {
    if(
this.beweegt && this.snelheid != 0)
        
alert(this.naam +" beweegt met een snelheid van "this.snelheid " knopen");
    else
        
alert(this.naam +" beweegt niet");
}

function 
rijtuig() {
    
this.heeft_wielen true;
    
this.snelheid 0// km/h
    
this.printrRijSnelheid printRijSnelheid;
}

function 
vaartuig() {
    
this.snelheid 0// knopen
    
this.printVaarSnelheid printVaarSnelheid;
}

rijtuig.prototype = new voertuig;
vaartuig.prototype = new voertuig;

boot = new vaartuig;
auto = new voertuig;

boot.naam 'De speedboot';
auto.naam 'De porche';

boot.setSnelheid(10);
boot.printBeweeg(); // output: Beweging!
boot.printVaarSnelheid(); // output: De speedboot beweegt met een snelheid van 10 knopen

auto.setSnelheid(100);
auto.printBeweeg('Vroem!');  // output: Vroem!
auto.setSnelheid(0); // motor afzetten;)
auto.printBeweeg('Vroem!'); // output: Staat stil


Ik hoop dat deze tutorial je wat heeft bijgebracht over de objecten en het manipuleren van objecten binnen javascript.
Ik vind dit alleszins een heel interessant onderwerp.
Als je vragen hebt, dan is er het javascript forum.
Javascript tutorial: Objecten, properties en prototypes in Javascript



« Vorige tutorial : Wachtwoord Beveiliging Volgende tutorial : WYSIWYG-editor »

© 2002-2024 Sitemasters.be - Regels - Laadtijd: 0.016s