Dieser Artikel teilt Ihnen hauptsächlich die detaillierte Erklärung der PHP-Standardspezifikationen mit und hofft, allen zu helfen.
wurde durch psr4 ersetzt, Sie können mehr darüber erfahren
1. Obligatorisch: Vollständig qualifizierter Namespace und Klassenformat :
2. Obligatorisch: Jeder Namespace muss einen Namensraum der obersten Ebene (Anbietername) haben.
3. Jeder Namespace kann eine beliebige Anzahl von Sub-Namespaces enthalten.
4. Wenn das Dateisystem die Quelldatei lädt, wird das Trennzeichen zwischen den Namespaces in DIRECTORY_SEPARATOR umgewandelt.
5. Unterstriche _ im Klassennamen
6. Vollständig qualifizierten Namespaces und Klassen wird das Suffix .php hinzugefügt, wenn Quelldateien aus dem Dateisystem geladen werden.
7. Buchstaben in einem vollständig qualifizierten Namensraum können beliebig kombiniert werden.
Beispiel
\Doctrine\Common\IsolatedClassLoader => /path/to/project/lib/vendor/Doctrine/Common/IsolatedClassLoader.php \Symfony\Core\Request => /path/to/project/lib/vendor/Symfony/Core/Request.php \Zend\Acl => /path/to/project/lib/vendor/Zend/Acl.php \Zend\Mail\Message => /path/to/project/lib/vendor/Zend/Mail/Message.php \namespace\package\Class_Name => /path/to/project/lib/vendor/namespace/package/Class/Name.php \namespace\package_name\Class_Name => /path/to/project/lib/vendor/namespace/package_name/Class/Name.php
Pflichtfeld: Das PHP-Tag muss oder = ?>2 sein . Obligatorisch: Die Datei muss in UTF-8 ohne BOM 3 codiert sein. Der Code in der PHP-Datei kann nur Deklarationen wie die Definition von Klassen, Funktionen, Konstanten usw. oder nur einige Nebenoperationen sein. 4. Namespaces und Klassen müssen psr0 oder psr45 erfüllen. Der Klassenname muss StudlyCaps [CamelCase-Namen beginnend mit einem Großbuchstaben] lauten. 6. Alle Buchstaben der Konstanten in der Klasse müssen großgeschrieben und durch Unterstriche getrennt werden. 7. Der Methodenname muss der CamelCase-Namensspezifikation entsprechen.
Erklärung
副操作包含却不仅限于:生成输出、直接的 require 或 include、连接外部服务、 修改 ini 配置、抛出错误或异常、修改全局或静态变量、读或写文件等。<?php// side effect: change ini settingsini_set('error_reporting', E_ALL);// side effect: loads a fileinclude "file.php";// side effect: generates outputecho "<html>\n";// declarationfunction foo(){ // function body}<?php// declarationfunction foo(){ // function body}// conditional declaration is not a side effectif (! function_exists('bar')) { function bar() { // function body } }
ist eine Erweiterung von psr1
1. Einrückung muss 4 sein Leerzeichen 3. Die Anzahl der Zeichen pro Zeile sollte sanft innerhalb von 80 gehalten werden. Theoretisch darf sie nicht mehr als 120 betragen, es darf jedoch keine feste Grenze geben. 4. Nach jeder Namespace-Deklaration und jedem Use-Deklarationsblock muss eine Leerzeile eingefügt werden. Alle Verwendungen müssen nach dem Namespace deklariert werden. 5. Die öffnenden Klammern von Methoden und Klassen müssen nach ihrer Deklaration in eine neue Zeile geschrieben werden. 6. abstract und final müssen vor den Modifikatoren private, protected und public stehen und static muss nach dem Zugriffsmodifikator deklariert werden. 7. Nach dem Schlüsselwort der Kontrollstruktur muss ein Leerzeichen stehen, beim Aufrufen einer Methode oder Funktion darf dies jedoch nicht der Fall sein. 8. Die öffnende geschweifte Klammer einer Kontrollstruktur muss in derselben Zeile wie die Deklaration geschrieben werden. 9. Nach der öffnenden linken Klammer und vor der schließenden rechten Klammer der Kontrollstruktur dürfen keine Leerzeichen stehen. 10. Alle PHP-Dateien müssen Unix LF als Zeilenabschlusszeichen verwenden.
11. Alle PHP-Dateien müssen mit einer Leerzeile enden. 12. Nach einer nicht leeren Zeile dürfen keine zusätzlichen Leerzeichen stehen. 13. Es darf nicht mehr als eine Anweisung pro Zeile geben. 14. Alle PHP-Schlüsselwörter müssen in Kleinbuchstaben geschrieben sein.
Instanz
<?phpnamespace Vendor\Package;use FooInterface;use BarClass as Bar;use OtherVendor\OtherPackage\BazClass;class Foo extends Bar implements FooInterface{ public function sampleMethod($a, $b = null) { if ($a === $b) { bar(); } elseif ($a > $b) { $foo->bar($arg1); } else { BazClass::bar($arg2, $arg3); } } final public static function bar() { // method body } }
Hinweis: Wird nach psr4 nicht mehr aufgerufen Vollqualifizierter Namespace, aber vollständig qualifizierter Klassenname. 1. Ein vollständig qualifizierter Klassenname muss einen Namensraum der obersten Ebene haben, der als „Anbieter-Namensraum“ bezeichnet wird. 2. Ein vollständig qualifizierter Klassenname kann einen oder mehrere Unternamensräume haben. 3. Ein vollständiger Klassenname muss einen endgültigen Klassennamen haben . Unterstriche haben keine besondere Bedeutung. 5. Der vollständige Klassenname kann aus beliebigen Groß- und Kleinbuchstaben bestehen. 6. Bei allen Klassennamen muss die Groß- und Kleinschreibung beachtet werden. 7. Entfernen Sie im vollständigen Klassennamen das erste Namespace-Trennzeichen, und der vorhergehende oder mehrere aufeinanderfolgende Namespaces und Unternamespaces werden als „Namespace-Präfix“ verwendet, das mindestens einem „Dateibasisverzeichnis“ entsprechen muss. Der Subnamespace, der unmittelbar auf das Namespace-Präfix folgt, muss mit dem entsprechenden „Dateibasisverzeichnis“ übereinstimmen und das Namespace-Trennzeichen wird als Verzeichnistrennzeichen verwendet. 9. Der Klassenname am Ende muss den gleichen Namen haben wie die entsprechende Datei mit dem Suffix .php. 10. Die Implementierung des Autoloaders darf keine Ausnahmen auslösen, darf keine Fehlermeldungen auslösen und sollte keinen Rückgabewert haben.
Beispiel
完整类名 | 命名空间前缀 | 文件基目录 | 文件路径 |
---|---|---|---|
AcmeLogWriterFile_Writer | AcmeLogWriter | ./acme-log-writer/lib/ | ./acme-log-writer/lib/File_Writer.php |
AuraWebResponseStatus | AuraWeb | /path/to/aura-web/src/ | /path/to/aura-web/src/Response/Status.php |
SymfonyCoreRequest | SymfonyCore | ./vendor/Symfony/Core/ | ./vendor/Symfony/Core/Request.php |
ZendAcl | Zend | /usr/includes/Zend/ | /usr/includes/Zend/Acl.php |
Verwandte Empfehlungen:
Beispiel zur Verwendung der PHP-Standardklasse (stdclass)
PHP-Standard-Bestätigungscode-Generierungsprogramm
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der PHP-Standardspezifikationen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!