PHP PSR-1 基本代碼規(guī)范(中文版)

基本代碼規(guī)范

本篇規(guī)范制定了代碼基本元素的相關(guān)標準, 以確保共享的PHP代碼間具有較高程度的技術(shù)互通性。
關(guān)鍵詞 “必須”("MUST")、“一定不可/一定不能”("MUST NOT")、“需要”("REQUIRED")、“將會”("SHALL")、“不會”("SHALL NOT")、“應(yīng)該”("SHOULD")、“不該”("SHOULD NOT")、“推薦”("RECOMMENDED")、“可以”("MAY")和”可選“("OPTIONAL")的詳細描述可參見 RFC 2119

1. 概覽

  • PHP代碼文件必須<?php<?= 標簽開始;

  • PHP代碼文件必須以 不帶BOM的 UTF-8 編碼;

  • PHP代碼中應(yīng)該只定義類、函數(shù)、常量等聲明,或其他會產(chǎn)生 從屬效應(yīng)的操作(如:生成文件輸出以及修改.ini配置文件等),二者只能選其一;

  • 命名空間以及類必須符合 PSR 的自動加載規(guī)范:PSR-0PSR-4 中的一個;

  • 類的命名必須遵循 StudlyCaps 大寫開頭的駝峰命名規(guī)范;

  • 類中的常量所有字母都必須大寫,單詞間用下劃線分隔;

  • 方法名稱必須符合 camelCase 式的小寫開頭駝峰命名規(guī)范。

2. 文件

  1. PHP標簽
    PHP代碼必須使用 <?php ?> 長標簽 或 <?= ?> 短輸出標簽;一定不可使用其它自定義標簽。
  2. 字符編碼
    PHP代碼必須且只可使用不帶BOM的UTF-8 編碼。
  3. 從屬效應(yīng)(副作用)
    一份PHP文件中應(yīng)該要不就只定義新的聲明,如類、函數(shù)或常量等不產(chǎn)生從屬效應(yīng)的操作,要不就只有會產(chǎn)生從屬效應(yīng)的邏輯操作,但不該同時具有兩者。
    “從屬效應(yīng)”(side effects)一詞的意思是,僅僅通過包含文件,不直接聲明類、 函數(shù)和常量等,而執(zhí)行的邏輯操作。
    “從屬效應(yīng)”包含卻不僅限于:生成輸出、直接的 require 或 include、連接外部服務(wù)、修改 ini 配置、拋出錯誤或異常、修改全局或靜態(tài)變量、讀或?qū)懳募取?br> 以下是一個反例,一份包含聲明以及產(chǎn)生從屬效應(yīng)的代碼:
    <?php
    // 從屬效應(yīng):修改 ini 配置 ini_set('error_reporting', E_ALL);
    // 從屬效應(yīng):引入文件
    include "file.php";
    // 從屬效應(yīng):生成輸出
    echo "<html>\n";
    // 聲明函數(shù)
    function foo(){ // 函數(shù)主體部分}

下面是一個范例,一份只包含聲明不產(chǎn)生從屬效應(yīng)的代碼:

    <?php
    // 聲明函數(shù)
    function foo(){ // 函數(shù)主體部分}
    // 條件聲明**不**屬于從屬效應(yīng)
    if (! function_exists('bar')) { function bar() { // 函數(shù)主體部分 }}

3. 命名空間和類

命名空間以及類的命名必須遵循 PSR-0.
根據(jù)規(guī)范,每個類都獨立為一個文件,且命名空間至少有一個層次:頂級的組織名稱(vendor name)。
類的命名必須 遵循 StudlyCaps
大寫開頭的駝峰命名規(guī)范。
PHP 5.3及以后版本的代碼必須使用正式的命名空間。
例如:

<?php
// PHP 5.3及以后版本的寫法
namespace Vendor\Model;
class Foo{}

5.2.x及之前的版本應(yīng)該使用偽命名空間的寫法,約定俗成使用頂級的組織名稱(vendor name)如 Vendor_
為類前綴。

<?php
// 5.2.x及之前版本的寫法
class Vendor_Model_Foo{}

4. 類的常量、屬性和方法

此處的“類”指代所有的類、接口以及可復(fù)用代碼塊(traits)

  1. 常量
    類的常量中所有字母都必須大寫,詞間以下劃線分隔。參照以下代碼:
<?php
namespace Vendor\Model;
class Foo{
  const VERSION = '1.0'; 
  const DATE_APPROVED = '2012-06-01';
}
  1. 屬性
    類的屬性命名可以遵循 大寫開頭的駝峰式 ($StudlyCaps)、小寫開頭的駝峰式 ($camelCase) 又或者是 下劃線分隔式 ($under_score),本規(guī)范不做強制要求,但無論遵循哪種命名方式,都應(yīng)該在一定的范圍內(nèi)保持一致。這個范圍可以是整個團隊、整個包、整個類或整個方法。
  2. 方法
    方法名稱必須符合 camelCase() 式的小寫開頭駝峰命名規(guī)范。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容