Variablenfunktionen

PHP unterstützt das Konzept der Variablenfunktionen. Wenn Sie an das Ende einer Variablen Klammern hängen, versucht PHP eine Funktion aufzurufen, deren Name der aktuelle Wert der Variablen ist. Dies kann unter anderem für Callbacks, Funktionstabellen usw. genutzt werden.

Variablenfunktionen funktionieren nicht mit Sprachkonstrukten wie echo, print, unset(), isset(), empty(), include und require. Um diese Konstrukte als Variablenfunktionen benutzen zu können, müssen Sie Ihre eigenen Wrapperfunktionen verwenden.

Beispiel #1 Beispiel für Variablenfunktionen

<?php
function foo() {
    echo 
"In foo()<br />\n";
}

function 
bar($arg '')
{
    echo 
"In bar(); der Parameter ist '$arg'.<br />\n";
}

// Dies ist eine Wrapperfunktion für echo
function echoit($string)
{
    echo 
$string;
}

$func 'foo';
$func();        // Dies ruft foo() auf

$func 'bar';
$func('test');  // Dies ruft bar() auf

$func 'echoit';
$func('test');  // Dies ruft echoit() auf
?>

Sie können auch die Methode eines Objektes mittels der Variablenfunktionen aufrufen.

Beispiel #2 Beispiel für eine Variablenmethode

<?php
class Foo
{
    function 
Variable()
    {
        
$name 'Bar';
        
$this->$name(); // Dies ruft die Methode Bar() auf
    
}

    function 
Bar()
    {
        echo 
"Das ist Bar";
    }
}

$foo = new Foo();
$funcname "Variable";
$foo->$funcname();  // Dies ruft $foo->Variable() auf

?>

Werden statische Methoden aufgerufen, ist der Funktionsaufruf stärker als der statische Eigenschaftsoperator:

Beispiel #3 Beispiel für Variablenmethoden mit statischen Eigenschaften

<?php
class Foo
{
    static 
$variable 'statische Eigenschaft';
    static function 
Variable()
    {
        echo 
'Method Variable called';
    }
}

echo 
Foo::$variable// Dies gibt 'statische Eigenschaft' aus. Es bräuchte
                     // eine $variable im aktuellen Geltungsbereich.
$variable "Variable";
Foo::$variable();  // Dies ruft $foo->Variable() auf, da $variable im
                   // aktuellen Geltungsbereich vorliegt.

?>

Beispiel #4 Komplexe Callables

<?php
class Foo
{
    static function 
bar()
    {
        echo 
"bar\n";
    }
    function 
baz()
    {
        echo 
"baz\n";
    }
}

$func = array("Foo""bar");
$func(); // gibt "bar" aus
$func = array(new Foo"baz");
$func(); // gibt "baz" aus
$func "Foo::bar";
$func(); // gibt "bar" aus
?>

Hier Kannst Du einen Kommentar verfassen


Bitte gib mindestens 10 Zeichen ein.
Wird geladen... Bitte warte.
* Pflichtangabe
Es sind noch keine Kommentare vorhanden.

PHP cURL-Tutorial: Verwendung von cURL zum Durchführen von HTTP-Anfragen

cURL ist eine leistungsstarke PHP-Erweiterung, die es Ihnen ermöglicht, mit verschiedenen Servern über verschiedene Protokolle wie HTTP, HTTPS, FTP und mehr zu kommunizieren. ...

TheMax

Autor : TheMax
Kategorie: PHP-Tutorials

Midjourney Tutorial - Anleitung für Anfänger

Über Midjourney, dem Tool zur Erstellung digitaler Bilder mithilfe von künstlicher Intelligenz, gibt es ein informatives Video mit dem Titel "Midjourney Tutorial auf Deutsch - Anleitung für Anfänger" ...

Mike94

Autor : Mike94
Kategorie: KI Tutorials

Grundlagen von Views in MySQL

Views in einer MySQL-Datenbank bieten die Möglichkeit, eine virtuelle Tabelle basierend auf dem Ergebnis einer SQL-Abfrage zu erstellen. ...

admin

Autor : admin
Kategorie: mySQL-Tutorials

Tutorial veröffentlichen

Tutorial veröffentlichen

Teile Dein Wissen mit anderen Entwicklern weltweit

Du bist Profi in deinem Bereich und möchtest dein Wissen teilen, dann melde dich jetzt an und teile es mit unserer PHP-Community

mehr erfahren

Tutorial veröffentlichen

[Wichtig] Anmeldung im Forum

Find all the latest apps at upcomingweb site (https://upcomingweb.com)

Geschrieben von upcomingweb am 28.01.2025 14:35:05
Forum: Fragen/Vorschläge zum Forum
xml for php processing

Hello everyone,,, I would like to further process the following value from this xml file: ext-id ext ...

Geschrieben von upcomingweb am 28.01.2025 14:29:03
Forum: XML
Einträge die älter als 24h sind in der PostgreSQL Datenbank löschen

hey sharbich :) manchmal liegt das Problem an den Spaltennamen oder Datentypen. Wenn die Spalte „created“ vom Typ timestamp ist, sollte Postgr ...

Geschrieben von Joan am 27.01.2025 10:01:35
Forum: SQL / Datenbanken
Berechnungen durchführen

Vielen Dank für das Teilen dieses nützlichen Wissens. Ich hoffe, Sie versorgen uns auch in Zukunft mit so vielen hervorragenden Beiträgen wie m ...

Geschrieben von huanmarries am 26.01.2025 11:20:37
Forum: PHP Developer Forum