Les classes en PHP
Si vous désirez plus d'informations sur les différents conçepts de l'orienté-objet, comme les notions de classe et d'encapsulation, vous pouvez consulter les pages relatives à l'orienté-objet.
Nous allons voir ici comment utiliser ces concepts pour coder en PHP orienté-objet.
Déclaration de classe
Il nous suffit d'utiliser le mot clé "class", suivi du nom de la classe, et des accolades pour délimiter le corps de la classe.
Constructeurs et destructeurs
Un constructeur est une méthode de la classe qui sera automatiquement appelée lors de la construction d'une nouvelle instance1.
Nous pouvons remarquer certaines différences entre PHP4 et PHP5 au niveau des constructeurs
- PHP4 : le constructeur porte le même nom que la classe.
- PHP5 : le constructeur porte un nom prédéfini "__construct()".
Par compartibilité descendante vers PHP4, nous pouvons encore utiliser le nom de la classe comme constructeur, mais autant prendre les bonnes habitudes...
Un destructeur est utilisé par le système lorsque l'objet n'est plus utilisé. Ceci nous permet de lancer automatiquement certaines actions à ce moment, ou de nous assurer que les variables utilisées seront bien libérées lorsque l'objet ne sera plus utilisé.
Exemple
Les attributs de la classe sont des variables internes à l'objet, qui ne sont accessibles qu'à travers celui-ci2. Leur déclaration se fait donc au sein de la déclaration de la classe, et nous pouvons contrôler les accès en masquant leur visibilité (en utilisant par exemple le mot clé "private") et en n'acceptant que les accès au travers de méthodes.
Les méthodes sont des fonctions internes à l'objet. Leur déclaration se fait donc au sein de la déclaration de la classe, de la même manière que pour les autres fonctions.Cependant, au contraire des fonctions qui ne se trouvent pas dans la classe, les méthodes peuvent accéder aux variables qui ne sont pas visibles de l'extérieur (private).
Instanciations en PHP
A présent que notre classe est définie, nous n'avons encore aucun objet.
Nous allons donc créer un objet (instance de la classe), ce qui revient à lui réserver un emplacement mémoire, et à lui donner un nom.
Les valeurs seront celles définies par défaut dans le constructeur, ou des valeurs passées en paramètres à ce dernier.
<?php $myobject = new myclass ("value"); $mytab[0] = new myclass ("value"); ?>
Pour créer un objet au travers de la classe, nous devons employer le mot clé "new" suivi du nom de la classe.
Nous venons donc de créer deux objets, un qui porte le nom myobject, et l'autre qui se trouve à l'index 0 (le premier indice) du tableau mytab.
A ces deux objets, nous affectons la valeur "value". Cette chaîne de caractères (La valeur est ici une chaîne de caractères, mais peut être une valeur numérique, un booléen, etc.) est passé en paramètre au constructeur.
Accès aux données
<?php $myobject->afficher(); ?>
L'accès aux attributs ou aux méthodes d'un objet se fait grâce à l'opérateur d'indirection (représenté par une flèche).
Exemple
<?php class BrolUser{ protected $id,$name,$mail; function __construct( $id = -1, $name = 'Inconnu', $mail = '' ){ $this->id = $id; $this->name = $name; } function __destruct(){ } public function getId(){ return $this->id; } public function getName(){ return $this->name; } public function getMail(){ } } ?>
Cet exemple semble assez clair, mais il risque de se compliquer par la suite, en fonction des besoins. Nous pouvons donc dès à présent prendre de bonnes habitudes, et commenter notre code comme le montre l'exemple suivant.
<?php /** * User base class * @version 20181014 * @since 20020319 * @package be.gaudry.infobrol.user */ class BrolUser{ // // ################################################################ // Declarations // /** * Integer, user id */ protected $id; /** * String, user name */ protected $name; /** * String, mail address */ protected $mail; // // ################################################################ // Constructor and destructor // /** * Basic brol user * * @param int $id user identifier * @param string $name username * @param string $mail user mail address * @version 20051022 */ function __construct( $id = -1, $name = 'Inconnu', $mail = '' ){ $this->id = $id; $this->name = $name; } /** * @version 20051022 */ function __destruct(){ } // // ################################################################ // Getters // public function getId(){ return $this->id; } public function getName(){ return $this->name; } public function getMail(){ } } ?>
Les deux exemples sont strictement identiques au niveau de leur exécution, mais le second sera plus facile à modifier et à comprendre. De plus, comme j'utilise Eclipse pour réaliser mes pages, cet éditeur affiche automatiquement les commentaires quand on appele une méthode, ce qui est bien pratique pour savoir quels arguments nous devons lui passer.
Nederlandse vertaling
U hebt gevraagd om deze site in het Nederlands te bezoeken. Voor nu wordt alleen de interface vertaald, maar nog niet alle inhoud.Als je me wilt helpen met vertalingen, is je bijdrage welkom. Het enige dat u hoeft te doen, is u op de site registreren en mij een bericht sturen waarin u wordt gevraagd om u toe te voegen aan de groep vertalers, zodat u de gewenste pagina's kunt vertalen. Een link onderaan elke vertaalde pagina geeft aan dat u de vertaler bent en heeft een link naar uw profiel.
Bij voorbaat dank.
Document heeft de 19/03/2002 gemaakt, de laatste keer de 26/10/2018 gewijzigd
Bron van het afgedrukte document:https://www.gaudry.be/nl/php-classes.html
De infobrol is een persoonlijke site waarvan de inhoud uitsluitend mijn verantwoordelijkheid is. De tekst is beschikbaar onder CreativeCommons-licentie (BY-NC-SA). Meer info op de gebruiksvoorwaarden en de auteur.