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

Buch über PHP, CSS und MySQL

Glad to see you're motivated to learn! For books on PHP, MySQL, and CSS, I recommend "PHP Objects, Patterns, and Practice" for a deeper look at PH ...

Geschrieben von JuanCarlson am 25.12.2024 11:13:41
Forum: Bücher-Forum
Abfrage in Datenbank

Hallo Zusammen und vielen Dank für die Aufnahme und somit Möglichkeit mich in PHP weiter zu entwickeln. Ich stehe aktuell vor einem Problem. Ich ...

Geschrieben von clancysway am 24.12.2024 03:52:14
Forum: SQL / Datenbanken
Finden Sie die Bestellungen des letzten Monats und die Gesamtausgaben

Erklärung der Änderungen Zeitraum-Filter: DATE_FORMAT(CURDATE() - INTERVAL 1 MONTH, '%Y-%m-01') gibt den ersten Tag des vorherigen Monats zu ...

Geschrieben von lauralorde am 24.12.2024 03:31:55
Forum: SQL / Datenbanken
Unlock a World of Sweet Success: How to Master Cookie Clicker!

Welcome to Cookie Clicker: A Treat for Gamers! If you love fun, casual games that inspire you to munch on virtual cookies while making strategic ...

Geschrieben von raleigh012 am 24.12.2024 02:40:23
Forum: Entwicklungsumgebungen