Bezüglich der neuen statischen verzögerten statischen Bindung oder späten statischen Bindung von PHP bin ich in Laravel auf ein Nutzungsproblem gestoßen. Wenn Sie das Modell in Laravel aufrufen, um neue Daten hinzuzufügen, fügen Sie wie folgt zunächst eine Methode zum Modell hinzu, um die Untertabelle abzurufen:
protected function addToMessage($msgType, $userID, $commentID, $replyCommentID, $replyUserID, $gameID) { if (!$userID) { return false; } $table = 't_message_' . hashID($userID, 100); $this->message->setTable($table)->create([ 'msg_type' => $msgType, 'user_id' => $userID, 'comment_id' => $commentID, 'reply_comment_id' => $replyCommentID, 'reply_user_id' => $replyUserID, 'game_id' => $gameID, 'is_read' => 0, 'created_at' => date('Y-m-d H:i:s'), ]); return true; }
Die setTable-Methode hier ist die im Modell definierte Methode zum Abrufen der Untertabelle -table:
public function setTable($table) { $this->table = $table; return $this; }
Ich habe im Fehlerprotokoll festgestellt, dass $this->table nicht wirksam wurde, aber tatsächlich war es der erwartete Wert, als der Tabellenname vor dem Aufruf der Methode create ausgegeben wurde Wurde $this->table nicht verwendet, als die Methode create hier aufgerufen wurde? Was ist mit Zurücksetzen?
Hier ist $this->message eine Modellklasse, die die Model-Klasse erbt, wobei sich die Erstellungsmethode:
public static function create(array $attributes = []) { $model = new static($attributes); $model->save(); return $model; }
in der Zeile 557 von sellerlaravelframeworksrcIlluminateDatabaseEloquentModel.php befindet.
Aufgrund des Laravel-Frameworks handelt es sich bei dieser Modellklasse um einen abstrakten Typ. In PHP können abstrakte Klassen mithilfe der neuen statischen, späten statischen Bindung instanziiert werden, und $model = new static($attributes) in der Methode create reinstanziiert tatsächlich und gibt zurück Der Aufruf der Model-Klasse definiert das Tabellenattribut nicht, daher hat $this->table zu diesem Zeitpunkt keinen Wert.
Die Lösung besteht darin, die Speichermethode zu verwenden, wie im Bild gezeigt. Tatsächlich ruft die Methode create auch die Methode save auf.
Experiment
Eine abstrakte Klasse A verfügt über eine Erstellungsmethode, die durch verzögerte statische Bindung instanziiert und zurückgegeben wird. Klasse B erbt A und das Namensattribut der übergeordneten Klasse wird in der Testmethode geändert.
<?php abstract class A { protected $name = "tanteng"; public static function create() { return new static(); } } class B extends A { //protected $name = '纸牌屋弗兰克'; public function test() { $this->name = "Tony Tan"; return $this; } } $obj1 = (new B)->test(); $obj2 = (new B)->test()->create(); var_dump($obj1); var_dump($obj2);
Die Ergebnisse zeigen, dass beide Instanzen von $obj1 und $obj2 Instanzen von B sind. Der Attributname hat sich durch den Aufruf der Testmethode geändert, aber das Namensattribut hat sich nach dem Aufruf der Erstellungsmethode nicht geändert. Dies ist die in diesem Artikel erwähnte Szene in Lavarel. (Wenn Sie den Kommentar hier aktivieren, ist der gedruckte Name der umgeschriebene Wert)
Wenn Sie die abstrakte Klasse A in eine normale Klasse ändern und „new static“ zur Instanziierung in „new self“ ändern, ist das Ergebnis anders , der gedruckte Der Attributname ist ein Attribut der jeweiligen Klasse.
Weitere technische Artikel zu Laravel finden Sie in der Spalte Einführungs-Tutorial zum Laravel-Framework, um mehr darüber zu erfahren!
Das obige ist der detaillierte Inhalt vonEine späte statische Bindung in Laravel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!