[oop] Domain-object: atributen vs array

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Lead C++ Developer

De rol van Lead C++ Developer Als Lead C++ developer bij KUBUS word je verantwoordelijk voor het implementatie design van requirements en de software architectuur van de desktop applicaties van BIMcollab, ons platform voor 3D model-validatie en issue-management bedoeld om de kwaliteit van 3D design-modellen voor gebouwen te verbeteren. Betere 3D modellen leiden tot betere gebouwen, dus zo draag je bij aan verduurzaming van de gebouwde omgeving met slimmer gebruik van materialen, minder verspilling en energie-efficiënte gebouwen. Een goede gebruikerservaring staat bij ons hoog in het vaandel; we gaan in onze ontwikkeling voor innovatie en kwaliteit. In je rol als

Bekijk vacature »

Front-end developer - working on software for arou

Functie They have recently started looking for an experienced Front-end (mobile/app) developer. Because of the short lines within the team, they are also looking for someone who can communicate with the service desk, sales and support for technical questions. You will join their IT team consisting of about 10 colleagues divided over two teams in rooms opposite each other. Half of these are involved in their front-end. You will work together with, among others, the Architect, 1 senior, 1 junior and there is a Team Leader. In terms of technology, they work with a unique tech-stack, particularly because of the

Bekijk vacature »

Senior Front end developer Angular

Functie Er zijn momenteel 5 SCRUM-teams waarvan drie gefocust zijn op DevOps en de huidige projecten en twee op innovatie van de platformen. Jij zal onderdeel worden van het innovatie Scrum team. De 2 multidisciplinaire innovatie teams bestaan momenteel uit 14 werknemers. Jij als senior Front end developer wordt onderdeel van onze innovatieteams. De innovatieteams houden zich bezig met het door ontwikkelen van de huidige producten en denken na over nieuwe functionaliteiten. Binnen de rol van Front end developer krijg je veel vrijheid en kan je je dag zelf indelen. Dingen waar jij je dagelijks mee bezig zult houden is

Bekijk vacature »

Consultant Low Code Developer

Functie omschrijving Heb jij verstand van datamodellering, NO CODE Platformen en kun jij het aan om projecten te leiden? Ben jij toe aan een nieuwe uitdaging en ben jij HBO afgestudeerd in de richting van IT? Voor een mooie opdrachtgever in omgeving Delft zijn wij op zoek naar een No Code developer die zich bezig gaat houden met het optimaliseren van bedrijfsprocessen bij klanten. Onderdelen functie Je gaat geen code kloppen maar bedenken hoe applicaties eruit moet komen te zien. Je gaat werken met een non code platform, je kunt denken aan Mendix of Betty Blocks. Je bent verantwoordelijk voor

Bekijk vacature »

Fullstack JavaScript developer (ReactJS, NodeJS, T

Functie Het team bestaat momenteel uit ruim 15 collega’s, waarvan ruim de helft in het ontwikkelteam werkzaam is. Er zijn gave plannen om het platform ook te gaan toepassen op bijv. vliegvelden, maar ook internationale groei zit in het verschiet en daarom zijn ze op zoek naar versterking. Als Fullstack JavaScript developer werk je nauw samen met 9 fullstack (Python en .NET) developers. Binnen het team ga jij je toespitsen op het creeren van de optimale toegankelijkheid en user experience. Om dit voor elkaar te krijgen zul je ontwerpen, programmeren, testen en implementeren. Het hele proces dus! Maar ook bijvoorbeeld

Bekijk vacature »

Senior Full Stack developer

Bedrijfsomschrijving tbd Functieomschrijving Full Stack Java Development bij Randstad Groep Nederland (HQ) Er is een vacature in het Corporate Client Solutions (CCS) team. Dit team is met een ander team net begonnen aan het project ‘Grip op Inhuur’. Het doel van dit project is de tevredenheid van onze leveranciers te verhogen en de efficiëntie van onze administratie te verbeteren. Onderdeel daarvan is een ‘Mijn-omgeving’ voor ZZP’ers en leveranciers. Naast dit nieuwe project werkt het team ook aan het onderhoud en verbeteren van een digitaal vacature management systeem waarmee dagelijks vele vacatures worden voorzien. Het team ontwikkelt zo veel mogelijk zelf

Bekijk vacature »

Senior Front-End Developer

Als Senior Front-End Developer bij Coolblue verbeter je de gebruiksvriendelijkheid van onze webshop voor miljoenen klanten. Wat doe je als Senior Front-End Developer bij Coolblue? Als Senior Front-end Developer werk je aan de gebruiksvriendelijkheid van onze webshop voor miljoenen klanten. Je vindt het leuk om samen te werken met de UX designer om stories op te pakken. Daarnaast ben je trots op je werk en verwelkomt alle feedback. Ook Senior Front-end Developer worden bij Coolblue? Lees hieronder of het bij je past. Dit vind je leuk om te doen Verbeteren van de gebruiksvriendelijkheid van onze webshop voor miljoenen klanten. Nadenken

Bekijk vacature »

React developer Inhouse cloudplatform

Functie De functie: Als front-end developer kom je te werken naast 2 andere front-end/React developers, waaronder één senior. Een hele mooie kans dus om in korte tijd veel nieuwe kennis en ervaring op te doen. Ze hebben momenteel veel werk hierin en daarom willen ze het team graag uitbreiden. Het is van belang dat je, zeker gezien het vele thuiswerken, in ieder geval al een aantal projecten hebt gedaan in React. Taken waar je aan kunt denken zijn het ontwikkelen van client-applicaties o.b.v. HTML5, React en andere open standaarden. Ook ben je nauw betrokken bij het implementeren van designs o.b.v.

Bekijk vacature »

Software developer

Functieomschrijving Voor een gewaardeerde werkgever in de regio van Middelburg zijn wij op zoek naar een ambitieuze PHP/Symfony Developer. Een enthousiast persoon die het development team komt versterken met het aanpakken van complexe en nieuwe projecten. Ben jij op zoek naar een baan met veel uitdaging binnen een snelgroeiend e-commerce bedrijf, waar je de tijd en ruimte krijgt voor zowel persoonlijke als professionele groei? Lees dan snel verder! Dit ga je doen: Aanpassingssuggesties van collega’s in kaart brengen, vervolgens te analyseren en daarna te concluderen of de aanpassing een verbetering is; Ontwikkeling en beheer van de serviceportal in Symfony en

Bekijk vacature »

C# .NET Software Ontwikkelaar

Functie omschrijving C# .NET Developer gezocht. Ben jij een full stack developer die op zoek is naar een nieuwe uitdaging binnen een leuk snel groeiend bedrijf? Lees dan snel verder! Wij zijn op zoek naar een Developer met ervaring op het gebied van .NET die een organisatie in de regio Arnhem gaat versterken. Jij gaat je binnen dit bedrijf vooral bezighouden met het verbeteren van de functionaliteiten van hun dataplatform. Samen met andere ontwikkelaars denk je mee in oplossingsrichtingen, architectuur en nieuwe technologieën. Als C# .NET Developer binnen dit bedrijf houd je je niet alleen bezig met het verbeteren van

Bekijk vacature »

Traineeship Java Developer

Functie Wat ga je doen als Java Developer? Jij start via ons bij deze opdrachtgever als Trainee Java ontwikkelaar, tijdens het traineeship ga je in 1 jaar van de basis naar professioneel Java ontwikkelaar. Je start samen met een groep trainees, volgt de aangeboden cursussen en gaat aan de slag bij één van onze opdrachtgevers. Na een aantal maanden volgt de volgende opdracht. Door de groei in jouw rol kom je op steeds complexere opdrachten terecht. Veel afwisseling dus. Collega’s met ervaring helpen je bij deze groei en samen met jouw coach ga je een persoonlijke leerplan opzetten om jou

Bekijk vacature »

Belastingdienst - Freelance Applicatieontwikkelaar

Startdatum: 01.06.2023 Richttarief: €65,00 - €75,00 Duur van de opdracht: 6 maanden Uren per week: 36 Taal: Nederlands vereist! Gelieve in het Nederlands te solliciteren. Hybride. Kantoordagen in Utrecht, incidenteel in Apeldoorn Functieomschrijving: De afdeling IV – Generieke Voorzieningen – Interactie Online is onderdeel van de keten Interactie. De missie van de keten is: “het faciliteren van de interactie met alle burgers, bedrijven en hun vertegenwoordigers om hen in staat te stellen aan hun fiscale verplichtingen te voldoen en aanspraak te maken op hun rechten.” De afdeling Interactie Online heeft een belangrijke bijdrage binnen deze keten. Dit door het ontwikkelen

Bekijk vacature »

SQL database developer

Functie omschrijving Voor een software bedrijf in omgeving Breda zijn wij op zoek naar een SQL database ontwikkelaar. Dit bedrijf bouwt applicaties om processen in distributiecentra te optimaliseren. Ter uitbreiding van het huidige team developers zijn wij op zoek naar een SQL database ontwikkelaar. De klanten van dit groeiende bedrijf zitten door heel Europa en jouw werkzaamheden zullen er als volgt uitzien: Het samenstellen van de software op basis van de input vanuit de klant (T-SQL & C#.NET). Het bezoeken van klanten om de processen en mogelijkheden in kaart te brengen. Het ontwerpen van databases met T-SQL als programmeer laag.

Bekijk vacature »

Full stack developer Node.js, React Remote

Functie Als fullstack JavaScript developer vind jij het uitdagend om op basis van concrete klantvragen nieuwe functionaliteiten te ontwikkelen. Bij voorkeur worden deze functionaliteiten op een bepaalde manier geprogrammeerd, zodat ze door meerdere klanten te gebruiken zijn. Je hebt dus vaak te maken met abstracte vraagstukken. Om dit te kunnen realiseren sta je nauw in contact met de product owner en/of klant. Je bent niet alleen onderdeel van het development team, maar hebt ook vaak contact met de product-owner en/of klanten om daardoor inzichten te verzamelen die leiden tot productverbeteringen. • Inzichten verzamelen bij de klant en/of product owner •

Bekijk vacature »

Java Developer

Dit ga je doen Als Java Developer ben je verantwoordelijk voor: Het ontwikkelen van nieuwe en bestaande webservices; Het uitbreiden van functionaliteiten binnen de producten- en dienstenportefeuille; Het werken aan gegevensuitwisseling met bijvoorbeeld SOAP; Testen van frameworks met gebruik van UNIT en Selenium. Hier ga je werken De organisatie waar je komt te werken is een semi-overheidsinstelling, gesitueerd in Utrecht en zorgt voor een goede samenwerking tussen verschillende overheidsinstanties. Het is een familiaire club die gaat voor kwaliteit en langdurige relaties. Zo zorgen zij ervoor dat er op grote schaal vertrouwelijke informatie tussen verschillende overheidsinstellingen wordt uitgewisseld. Hun werk zorgt

Bekijk vacature »
Jasper DS

Jasper DS

08/03/2013 10:53:17
Quote Anchor link
Hallo,

ik denk dat dit onderwerp al een aantal keren besproken is maar hoe zouden jullie te werk gaan met een domain object (= een class / object dat data vasthoud / valideert)?

Verkiezen jullie gedefinieerde attributen zoals:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
<?php

namespace Jds\Models\User;

class User
{
    private $id;
    private $email;
    private $password;

    /* particulier */
    private $firstname;
    private $lastname;
    private $birthdate;

    /* Zakelijk */
    private $naam;
    private $btw_nummer;
    private $contactpersoon;

    private $type;
    private $adress;
    private $city;
    private $country;
    private $postalCode;


    public function __construct($email)
    {

        $this->setEmail($email);
    }


    public function getKey()
    {

         return 'user';
    }


    public function setId($newId)
    {

        $this->id = $newId;
    }


    public function setName($newName)
    {

        $this->name = $newName;
    }


    public function setPassword($newPassword)
    {

        $this->password = $newPassword;
    }


    public function setEmail($newEmail)
    {

        $this->email = $newEmail;
    }


    public function setAdress($adress)
    {

        $this->adress = $adress;
    }


    public function setCity($city)
    {

        $this->city = $city;
    }


    public function setPostalCode($postalcode)
    {

        $this->postalCode = $postalcode;
    }


    public function setType($type)
    {

        $this->type = $type;
    }


    public function setCountry($country)
    {

        $this->country = $country;
    }


    public function setFirstName($firstname)
    {

        $this->firstname = $firstname;
    }


    public function setLastName($lastname)
    {

        $this->lastname = $lastname;
    }


    public function setBirthDate($birthdate)
    {

        $this->birthdate = $birthdate;
    }


    public function getId()
    {

        return $this->id;
    }


    public function getName()
    {

        return $this->getLastName() . ' ' . $this->getFirstName();
    }


    public function getFirstName()
    {

        return $this->firstname;
    }


    public function getLastName()
    {

        return $this->lastname;
    }


    public function getPassword()
    {

        return $this->password;
    }


    public function getEmail()
    {

        return $this->email;
    }


    public function getAdress()
    {

        return $this->adress;
    }


    public function getCity()
    {

        return $this->city;
    }


    public function getPostalCode()
    {

        return $this->postalCode;
    }


    public function getCountry()
    {

        return $this->country;
    }



    public function getType()
    {

        return $this->type;
    }


    public function getBirthDate()
    {

        return $this->birthdate;
    }


    public function getBTW()
    {

        return $this->btw_nummer;
    }

}

?>


of eerder een array:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
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
<?php
class User
{
    private $properties = array();

    public function setProperty($key, $value)
    {

        $this->$properties[$key] = $array;
    }


    public function getProperty($key)
    {

        return $this->$properties[$key];
    }


    public function setProperties(array $values)
    {

        $this->$properties = $values;
    }


    public function getProperties()
    {

        return $this->$properties;    
    }

}

?>


Ik vind het langs de éne kant wel goed dat ik alleen aan mijn vastgestelde attributen geraak via de getters (voorbeeld1). Het nadeel is dat ik nooit snel alle attributen kan ophalen (bijvoorbeeld voor een insert.)
Gewijzigd op 08/03/2013 10:56:20 door Jasper DS
 
PHP hulp

PHP hulp

03/12/2024 18:18:26
 
Erwin H

Erwin H

08/03/2013 10:58:08
Quote Anchor link
Getters en setters zou je kunnen doen. Opslaan zou ik altijd in een array doen. Hoe een class intern werkt is niet van belang voor de buitenwacht, dus bij naam gedefinieerde properties dient geen enkel doel. Een array is dan veel efficienter omdat je flexibeler bent en properties die geen waarde hebben bestaan op dat moment ook niet in het geheugen. Daarnaast kan je ook nog eens runtime properties definieren (mocht dat nodig zijn) via anonieme getters en setters.
 
Ozzie PHP

Ozzie PHP

08/03/2013 11:07:14
Quote Anchor link
Het hangt er vanaf of je weet wat voor properties je wilt opslaan. Er zijn situaties waar je van tevoren niet weet wat je allemaal wilt opslaan. In dat geval is de 2e optie (opslaan in een array) de juiste. Hou er rekening mee dat overal waar in jouw code $this->$properties staat dit $this->properties moet zijn.

Als de properties wel bekend zijn, zoals bij een user, dan zou ik met specifieke setters en getters werken en met specifieke class properties, zoals in voorbeeld 1. Die class properties zijn daar namelijk voor bedoeld. Een voornaam is een property/eigenschap van een user/gebruiker.
 
Jasper DS

Jasper DS

08/03/2013 11:23:38
Quote Anchor link
Dan moet ik mijn insert functie aanpassen. Daar komt nu het user object binnen maar ik wil een snelle methode om inneens al mijn properties in de query te kunnen zetten zonder dat ik al mijn getters moet aanroepen.
 
Ozzie PHP

Ozzie PHP

08/03/2013 11:36:52
Quote Anchor link
Jasper, volgens mij hoeft dat niet. Volgens mij kun je een functie getProperties maken. Zoiets:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
<?php
public function getProperties() {
    $properties = get_object_vars($this);
    foreach ($properties as $property => $value) {
        echo $property . ' ' . $value . '<br>';
    }
}

?>


Ik heb dit niet getest, maar als het goed is zou je nu alle properties met hun waarden op het scherm moeten zien. In plaats van een echo, ga je dan een INSERT toepassen.
 
Erwin H

Erwin H

08/03/2013 11:40:49
Quote Anchor link
Waarom zou je dat doen Ozzie? Lijkt mij een beetje het paard achter de wagen spannen. Hoe je een property intern opslaat is niet erg van belang. Of je alle gegevens nu in aparte variabelen hebt zitten, of in 1 array, het property wordt gedefinieerd door hoe je het kunt setten en getten, niet door hoe het opgeslagen is. Om nu strikt vol te houden aan aparte variabelen omdat dat de definitie van een property zou zijn (...) maakt het alleen maar lastiger.
 
Ozzie PHP

Ozzie PHP

08/03/2013 11:50:57
Quote Anchor link
Erwin, dat is toch gewoon een kwestie van persoonlijke voorkeur? Jij vraagt waarom zou je dat doen? Dan vraag ik waarom zou je het niet doen? Zoals voor veel dingen in het programmeren geldt dat er meerdere wegen zijn die naar Rome leiden.

Een class property is een eigenschap van een object. Een voornaam, achternaam, geboortedatum enz. zijn allemaal eigenschappen van een user. Uiteraard kunnen we die allemaal in één property gooien. Dan zou je voortaan in iedere class nog maar één property nodig hebben waar je alles in stopt. Volgens mij is dat niet de juiste gedachte.

Als je een object schematisch weergeeft (bijvoorbeeld via var_dump) dan zou je in jouw geval zoiets krijgen:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
object:     user
properties: properties


In mijn geval zou je dan zoiets krijgen:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
object:     user
properties: day_of_birth
            email_address
            first_name
            last_name


Persoonlijk vind ik dat mijn afspiegeling van het object een duidelijkere en volledigere weergave geeft van wat het object inhoudt.
 
Erwin H

Erwin H

08/03/2013 12:13:49
Quote Anchor link
Ozzie PHP op 08/03/2013 11:50:57:
Erwin, dat is toch gewoon een kwestie van persoonlijke voorkeur? Jij vraagt waarom zou je dat doen? Dan vraag ik waarom zou je het niet doen?

Dat klopt natuurlijk helemaal en ik heb een duidelijke reden waarom ik dat in dit geval niet zou doen. Namelijk omdat het makkelijker en efficienter is zoals ik boven heb uitgelegd. Dat maakt het inderdaad niet de ultieme waarheid, maar wel waarom ik het zo zou doen, in dit geval (en het dus adviseer).

Ozzie PHP op 08/03/2013 11:50:57:
Een class property is een eigenschap van een object. Een voornaam, achternaam, geboortedatum enz. zijn allemaal eigenschappen van een user. Uiteraard kunnen we die allemaal in één property gooien. Dan zou je voortaan in iedere class nog maar één property nodig hebben waar je alles in stopt. Volgens mij is dat niet de juiste gedachte.

Wat mij betreft haal je nu de begrippen property en variabele door elkaar. Een property, in mijn ogen, is een eigenschap van een object en kan je opvragen en/of bepalen door middel van getters en setters. Ik ben het met je eens dat het mooier (en in de meeste gevallen beter) is om voor elk property een eigen getter en setter te maken zodat het duidelijk is wat de properties zijn.

Jij trekt dit nu echter door naar de variabele waarin een property wordt opgeslagen. dat vind ik te ver gaan. Elk property hoeft niet zijn eigen variabele te hebben. Sterker, in veel gevallen kan dat niet eens, of is het in elk geval niet verstandig. Neem een container object dat bijvoorbeeld een reeks aan andere objecten beheert. Een heel nuttig property (read only weliswaar) van dat container object zal zijn het aantal objecten dat dat object beheert. Daar heb je dus een getter voor. Alleen geen variabele, want op het moment dat je het uitleest, zal het object het aantal objecten tellen en dat teruggeven.

Dus hoe je de gegevens opslaat voor de properties staat los van de properties. In sommige gevallen, zoals hier, zal het gebruik van je class bepalen hoe je het het beste kunt opslaan. Als je, zoals in dit geval, van te voren al weet dat je alle properties samen vaak nodig zult gaan hebben in een array, waarom sla je het dan niet gewoon op in een array? Scheelt je een hoop moeilijkheden als je ze allemaal wilt uitlezen.
Gewijzigd op 08/03/2013 12:15:19 door Erwin H
 
Ozzie PHP

Ozzie PHP

08/03/2013 12:24:26
Quote Anchor link
"Een property, in mijn ogen, is een eigenschap van een object en kan je opvragen en/of bepalen door middel van getters en setters."

Precies... en ik vind dat een voornaam, achternaam of e-mailadres allemaal properties zijn van een User.

"Ik ben het met je eens dat het mooier (en in de meeste gevallen beter) is om voor elk property een eigen getter en setter te maken"

Mooi, dan zijn we het daar over eens :-)

"Een heel nuttig property (read only weliswaar) van dat container object zal zijn het aantal objecten dat dat object beheerd."

Dan kom je weer terug op wat ik in het begin zei. Ik zou voor properties die bekend zijn een eigen property aanmaken. In container classes ligt de situatie anders, omdat je vantevoren niet weet wat je er allemaal in gaat stoppen. Stel we hebben een class met daarin de bestelling van een klant. De klant heeft 5 producten gekocht. Dan kun je de property count instellen op 5 omdat je het exacte aantal kent. Voor een container (of aanverwante class) geldt dat niet, alhoewel je ook hier een property zou kunnen instellen en ophogen op het moment dat er iets wordt toegevoegd. Maar je moet je sowieso afvragen of "aantal" een eigenschap is van een object.

Anyhow, misschien is het leuk als iemand anders ook zijn blik erop laat schijnen. Hoe meer inzichten, des te interessanter.
 
Erwin H

Erwin H

08/03/2013 12:27:53
Quote Anchor link
Ozzie PHP op 08/03/2013 12:24:26:
Precies... en ik vind dat een voornaam, achternaam of e-mailadres allemaal properties zijn van een User.

Ozzie, je mist mijn hele punt volgens mij.....
Probeer te begrijpen dat ik onderscheid maak tussen property en variabele. Dat begrip mis ik namelijk in je antwoord.
 
Ozzie PHP

Ozzie PHP

08/03/2013 12:34:28
Quote Anchor link
Dan moet je even uitleggen wat je bedoelt. Ik zie een naam als een property (eigenschap) van een gebruiker (object).
 
Erwin H

Erwin H

08/03/2013 12:52:36
Quote Anchor link
Jij zegt:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
<?php
class Test{
  private $voornaam;

  public function getVoornaam(){
    return $this->voornaam;
  }


  public function setVoornaam( $voornaam ){
    $this->voornaam = $voornaam;
  }
}

?>

is beter dan:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
<?php
class Test{
  private $data = array();

  public function get( $key ){
    return $this->data[$key];
  }


  public function set( $key, $value ){
    $this->data[$key] = $value;
  }
}

?>

Want in het tweede geval mis je de benoemde properties. Ben ik met je eens.

Wat ik echter zeg is dat er een tussenvorm is, die in dit geval veel handiger is. Laat los dat elke property zijn eigen variabele moet hebben (maar wel zijn eigen getters en setters) en dan krijg je dit:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<?php
//even zonder isset tests om het makkelijk te houden.
class Test{
  private $data = array();

  public function getVoornaam(){
    return $this->data['voornaam'];
  }


  public function setVoornaam( $voornaam ){
    $this->$data['voornaam'] = $voornaam;
  }
}

?>

De externe interface is identiek aan het door jou geprefereerde model met aparte properties. Ik kan zien dat deze class een property voornaam heeft, ik ken het setten en getten. Echter, ik sla het op een array, want dan kan ik veel makkelijker alle properties in een keer teruggeven als dat nodig is.
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
<?php
  public function getAll(){
    return $data;
  }

?>

Opmerking: ja, je moet dan wel zorgen dat het ontvangende object weet dat mogelijk niet alle properties geset zijn.
 
Ozzie PHP

Ozzie PHP

08/03/2013 13:02:41
Quote Anchor link
Ik snap wat je bedoelt, dus wat dat betreft zeg je hiermee niks nieuws. Ik denk alleen dat het instellen van een property $data te globaal is. Voor een container of config class waarbij je vantevoren de properties niet kent is het prima. Echter, als je de properties wel kent denk ik dat het veel netter is om ze ook te gebruiken. Aan de werking doet het inderdaad niks af, maar aan het OOP principe wellicht wel.

Wellicht kan iemand anders er ook eens zijn licht over laten schijnen.
 
Erwin H

Erwin H

08/03/2013 13:08:51
Quote Anchor link
Nee ik bedenk niet opeens iets nieuws :-)

Dan verschillen we dus van mening, maar begrijpen we elkaar wel weer. Verder aan Jasper welke kant hij op wil.
 
Jasper DS

Jasper DS

08/03/2013 15:17:38
Quote Anchor link
Bedankt voor jullie mening! Ik ben nog steeds aan het twijfelen. ;-) Ik was ook nog aan het denken om een functie als http://php.net/manual/en/function.get-object-vars.php te gebruiken maar dat werkt alleen voor public properties en die van mij staan op private omdat ze niet van buiten af mogen aangesproken worden (daar dient de getter en setter voor).



edit:
ik denk dat ik het zo ga doen (zie onder), vinden jullie dat een acceptabel idee?
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
public function getProperties()
    {
        return get_object_vars($this);
    }
Gewijzigd op 08/03/2013 15:22:10 door Jasper DS
 
Erwin H

Erwin H

08/03/2013 15:25:41
Quote Anchor link
Je moet alleen oppassen dat je niet op zeker moment de class uitbreidt met properties die niets te maken hebben met de user data (uitgaande van dat dit over een user object gaat). Als je bijvoorbeeld een property hebt voor een ander object, bijvoorbeeld een service container link oid, dan wordt die zo ook mee teruggegeven. Dit kan ook mogelijk ook het geval zijn als je deze class later gaat extenden. Zo krijg je dus wel onverwacht gedrag.
 
Ward van der Put
Moderator

Ward van der Put

08/03/2013 16:20:42
Quote Anchor link
Erwin H op 08/03/2013 15:25:41:
Dit kan ook mogelijk ook het geval zijn als je deze class later gaat extenden. Zo krijg je dus wel onverwacht gedrag.
Inderdaad, en de wortels van waar het straks fout gaat, vind je in dit fragment:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
<?php
class User
{
    /* particulier */
    private $firstname;
    private $lastname;
    private $birthdate;

    /* Zakelijk */
    private $naam;
    private $btw_nummer;
    private $contactpersoon;
?>

Een particulier heeft een $firstname en $lastname, een bedrijf een $naam met een $contactpersoon?

Je kunt eigenlijk weinig zinnigs zeggen over getters en setters als je model nog niet af is. Dat zie je in de startpost: alle setters doen $this->A = $a en alle getters doen return $this->A, maar verder doen ze helemaal niets.

Een e-mailadres wordt daarmee hetzelfde als een naam en die zijn beide vergelijkbaar met een btw-nummer. Als je het zó doet, dan kun je evengoed alles in een array stoppen. Maar uiteindelijk wil je dat waarschijnlijk niet.
 
Ozzie PHP

Ozzie PHP

08/03/2013 16:29:43
Quote Anchor link
Jasper DS op 08/03/2013 15:17:38:
Bedankt voor jullie mening! Ik ben nog steeds aan het twijfelen. ;-) Ik was ook nog aan het denken om een functie als http://php.net/manual/en/function.get-object-vars.php te gebruiken maar dat werkt alleen voor public properties en die van mij staan op private omdat ze niet van buiten af mogen aangesproken worden (daar dient de getter en setter voor).



edit:
ik denk dat ik het zo ga doen (zie onder), vinden jullie dat een acceptabel idee?
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
public function getProperties()
    {
        return get_object_vars($this);
    }

Euh, deze functie gaf ik je in mijn eerdere post al... gemist?
 



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.