Files
doc-fr/reference/classobj/examples.xml
Yannick Torres d24dba8436 initiale translation
git-svn-id: https://svn.php.net/repository/phpdoc/fr/trunk@257264 c90b9560-bf6c-de11-be94-00142212c4b1
2008-04-11 21:17:00 +00:00

181 lines
3.8 KiB
XML

<?xml version="1.0" encoding="iso-8859-1"?>
<!-- $Revision: 1.1 $ -->
<!-- EN-Revision: 1.2 Maintainer: yannick Status: ready -->
<!-- Reviewed: no -->
<appendix xml:id="classobj.examples">
&reftitle.examples;
<para>
Dans cet exemple, nous commençons par définir une classe
de base ainsi qu'une extension de cette classe. La classe
de base un légume, s'il est éditable et qu'elle est sa couleur.
La sous-classe <varname>Spinach</varname> ajoute une méthode
pour le cuisiner, si possible.
</para>
<para>
<example>
<title>classes.inc</title>
<programlisting role="php">
<![CDATA[
<?php
// classe de base, avec les propriétés des membres et des méthodes
class Vegetable {
var $edible;
var $color;
function Vegetable($edible, $color="green")
{
$this->edible = $edible;
$this->color = $color;
}
function is_edible()
{
return $this->edible;
}
function what_color()
{
return $this->color;
}
} // fin de la classe Vegetable
// extend la classe de base
class Spinach extends Vegetable {
var $cooked = false;
function Spinach()
{
$this->Vegetable(true, "green");
}
function cook_it()
{
$this->cooked = true;
}
function is_cooked()
{
return $this->cooked;
}
} // fin de la classe Spinach
?>
]]>
</programlisting>
</example>
</para>
<para>
Puis, instançions 2 objets depuis ces classes et affichons
les informations sur ces dernières, incluant leur classe
parente. Nous définissons également des fonctions utilitaires,
afin d'avoir un affichage plus joli des variables.
</para>
<para>
<example>
<title>test_script.php</title>
<programlisting role="php">
<![CDATA[
<pre>
<?php
include "classes.inc";
// fonctions utiles
function print_vars($obj)
{
foreach (get_object_vars($obj) as $prop => $val) {
echo "\t$prop = $val\n";
}
}
function print_methods($obj)
{
$arr = get_class_methods(get_class($obj));
foreach ($arr as $method) {
echo "\tfonction $method()\n";
}
}
function class_parentage($obj, $class)
{
if (is_subclass_of($GLOBALS[$obj], $class)) {
echo "L'objet $obj appartient à la classe " . get_class($$obj);
echo " une sous-classe de $class\n";
} else {
echo "L'object $obj n'appartient pas à la sous-classe $class\n";
}
}
// instanciation des 2 objets
$veggie = new Vegetable(true, "blue");
$leafy = new Spinach();
// Afifchage des informations des objets
echo "veggie: CLASS " . get_class($veggie) . "\n";
echo "leafy: CLASS " . get_class($leafy);
echo ", PARENT " . get_parent_class($leafy) . "\n";
// affichage de la propriété veggie
echo "\nveggie: Propriétés\n";
print_vars($veggie);
// et enfin, les méthodes
echo "\nleafy: Méthodes\n";
print_methods($leafy);
echo "\nClasse parente :\n";
class_parentage("leafy", "Spinach");
class_parentage("leafy", "Vegetable");
?>
</pre>
]]>
</programlisting>
<para>
Une chose importante à noter dans l'exemple ci-dessus est
que l'objet <varname>$leafy</varname> est une instance
de la classe <classname>Spinach</classname> qui est une
sous-classe de <classname>Vegetable</classname>,
toutefois, la dernière partie de ce script affichera :
</para>
<screen>
<![CDATA[
[...]
Classe parente :
L'object leafy n'appartient pas à la sous-classe Spinach
L'object leafy appartient à la classe spinach une sous-classe de Vegetable
]]>
</screen>
</example>
</para>
</appendix>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"../../../manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->