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.
English translation
You have asked to visit this site in English. For now, only the interface is translated, but not all the content yet.If you want to help me in translations, your contribution is welcome. All you need to do is register on the site, and send me a message asking me to add you to the group of translators, which will give you the opportunity to translate the pages you want. A link at the bottom of each translated page indicates that you are the translator, and has a link to your profile.
Thank you in advance.
Document created the 19/03/2002, last modified the 26/10/2018
Source of the printed document:https://www.gaudry.be/en/php-classes.html
The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.