<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/language.attributes.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'de',
  ),
  'this' => 
  array (
    0 => 'language.attributes.reflection.php',
    1 => 'Lesen von Attributen mit der Reflection-API',
    2 => 'Lesen von Attributen mit der Reflection-API',
  ),
  'up' => 
  array (
    0 => 'language.attributes.php',
    1 => 'Attribute',
  ),
  'prev' => 
  array (
    0 => 'language.attributes.syntax.php',
    1 => 'Syntax von Attributen',
  ),
  'next' => 
  array (
    0 => 'language.attributes.classes.php',
    1 => 'Deklaration von Attributklassen',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'de',
    'path' => 'language/attributes.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="language.attributes.reflection" class="sect1">
   <h2 class="title">Lesen von Attributen mit der Reflection-API</h2>

   <p class="para">
    Mit der von der Reflection-API bereitgestellten Methode
    <span class="function"><strong>getAttributes()</strong></span> kann auf die Attribute von Klassen,
    Methoden, Funktionen, Parametern, Eigenschaften und Klassenkonstanten
    zugegriffen werden. Diese Methode gibt ein Array von
    <span class="classname"><a href="class.reflectionattribute.php" class="classname">ReflectionAttribute</a></span>-Instanzen zurück. Diese
    Instanzen können nach dem Attributnamen und den Argumenten abgefragt werden
    und können verwendet werden, um eine Instanz des dargestellten Attributs zu
    instanziieren.
   </p>

   <p class="para">
    Die Trennung der Repräsentation des reflektierten Attributs von seiner
    tatsächlichen Instanz ermöglicht eine bessere Kontrolle über die Behandlung
    von Fehlern wie fehlende Attributklassen, falsch eingegebene Argumente oder
    fehlende Werte. Objekte der Attributklasse werden erst nach dem Aufruf der
    Funktion <span class="function"><a href="reflectionattribute.newinstance.php" class="function">ReflectionAttribute::newInstance()</a></span>
    instanziiert, um sicherzustellen, dass die Validierung der Argumente zu
    diesem Zeitpunkt erfolgt.
   </p>

   <div class="example" id="example-1">
    <p><strong>Beispiel #1 Lesen von Attributen mit der Reflection-API</strong></p>

    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #007700">#[</span><span style="color: #0000BB">Attribute</span><span style="color: #007700">]<br />class </span><span style="color: #0000BB">MyAttribute<br /></span><span style="color: #007700">{<br />    public </span><span style="color: #0000BB">$value</span><span style="color: #007700">;<br /><br />    public function </span><span style="color: #0000BB">__construct</span><span style="color: #007700">(</span><span style="color: #0000BB">$value</span><span style="color: #007700">)<br />    {<br />        </span><span style="color: #0000BB">$this</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">value </span><span style="color: #007700">= </span><span style="color: #0000BB">$value</span><span style="color: #007700">;<br />    }<br />}<br /><br />#[</span><span style="color: #0000BB">MyAttribute</span><span style="color: #007700">(</span><span style="color: #0000BB">value</span><span style="color: #007700">: </span><span style="color: #0000BB">1234</span><span style="color: #007700">)]<br />class </span><span style="color: #0000BB">Thing<br /></span><span style="color: #007700">{<br />}<br /><br />function </span><span style="color: #0000BB">dumpAttributeData</span><span style="color: #007700">(</span><span style="color: #0000BB">$reflection</span><span style="color: #007700">) {<br />    </span><span style="color: #0000BB">$attributes </span><span style="color: #007700">= </span><span style="color: #0000BB">$reflection</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getAttributes</span><span style="color: #007700">();<br /><br />    foreach (</span><span style="color: #0000BB">$attributes </span><span style="color: #007700">as </span><span style="color: #0000BB">$attribute</span><span style="color: #007700">) {<br />       </span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$attribute</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getName</span><span style="color: #007700">());<br />       </span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$attribute</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getArguments</span><span style="color: #007700">());<br />       </span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$attribute</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">newInstance</span><span style="color: #007700">());<br />    }<br />}<br /><br /></span><span style="color: #0000BB">dumpAttributeData</span><span style="color: #007700">(new </span><span style="color: #0000BB">ReflectionClass</span><span style="color: #007700">(</span><span style="color: #0000BB">Thing</span><span style="color: #007700">::class));<br /></span><span style="color: #FF8000">/*<br />string(11) "MyAttribute"<br />array(1) {<br />  ["value"]=&gt;<br />  int(1234)<br />}<br />object(MyAttribute)#3 (1) {<br />  ["value"]=&gt;<br />  int(1234)<br />}<br />*/</span></span></code></div>
    </div>

   </div>

   <p class="para">
    Anstatt alle Attribute der Reflection-Instanz zu durchlaufen, kann auch der
    Name einer bestimmten Attributklasse als Argument übergeben werden, um nur
    die Attribute dieser Attributklasse abzurufen.
   </p>

   <div class="example" id="example-2">
    <p><strong>Beispiel #2 Lesen bestimmter Attribute mit der Reflection-API</strong></p>

    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #007700">function </span><span style="color: #0000BB">dumpMyAttributeData</span><span style="color: #007700">(</span><span style="color: #0000BB">$reflection</span><span style="color: #007700">) {<br />    </span><span style="color: #0000BB">$attributes </span><span style="color: #007700">= </span><span style="color: #0000BB">$reflection</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getAttributes</span><span style="color: #007700">(</span><span style="color: #0000BB">MyAttribute</span><span style="color: #007700">::class);<br /><br />    foreach (</span><span style="color: #0000BB">$attributes </span><span style="color: #007700">as </span><span style="color: #0000BB">$attribute</span><span style="color: #007700">) {<br />       </span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$attribute</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getName</span><span style="color: #007700">());<br />       </span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$attribute</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getArguments</span><span style="color: #007700">());<br />       </span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$attribute</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">newInstance</span><span style="color: #007700">());<br />    }<br />}<br /><br /></span><span style="color: #0000BB">dumpMyAttributeData</span><span style="color: #007700">(new </span><span style="color: #0000BB">ReflectionClass</span><span style="color: #007700">(</span><span style="color: #0000BB">Thing</span><span style="color: #007700">::class));</span></span></code></div>
     </div>

    </div>
  </div><?php manual_footer($setup); ?>