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

基本代碼規(guī)范

本篇規(guī)范制定了代碼基本元素的相關(guān)標(biāo)準(zhǔn), 以確保共享的PHP代碼間具有較高程度的技術(shù)互通性指厌。
關(guān)鍵詞 “必須”("MUST")、“一定不可/一定不能”("MUST NOT")踊跟、“需要”("REQUIRED")踩验、“將會(huì)”("SHALL")、“不會(huì)”("SHALL NOT")商玫、“應(yīng)該”("SHOULD")晰甚、“不該”("SHOULD NOT")、“推薦”("RECOMMENDED")决帖、“可以”("MAY")和”可選“("OPTIONAL")的詳細(xì)描述可參見(jiàn) RFC 2119 厕九。

1. 概覽

  • PHP代碼文件必須<?php<?= 標(biāo)簽開(kāi)始;

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

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

  • 命名空間以及類(lèi)必須符合 PSR 的自動(dòng)加載規(guī)范:PSR-0PSR-4 中的一個(gè)细睡;

  • 類(lèi)的命名必須遵循 StudlyCaps 大寫(xiě)開(kāi)頭的駝峰命名規(guī)范谷羞;

  • 類(lèi)中的常量所有字母都必須大寫(xiě),單詞間用下劃線分隔溜徙;

  • 方法名稱(chēng)必須符合 camelCase 式的小寫(xiě)開(kāi)頭駝峰命名規(guī)范湃缎。

2. 文件

  1. PHP標(biāo)簽
    PHP代碼必須使用 <?php ?> 長(zhǎng)標(biāo)簽 或 <?= ?> 短輸出標(biāo)簽;一定不可使用其它自定義標(biāo)簽蠢壹。
  2. 字符編碼
    PHP代碼必須且只可使用不帶BOM的UTF-8 編碼嗓违。
  3. 從屬效應(yīng)(副作用)
    一份PHP文件中應(yīng)該要不就只定義新的聲明,如類(lèi)图贸、函數(shù)或常量等不產(chǎn)生從屬效應(yīng)的操作蹂季,要不就只有會(huì)產(chǎn)生從屬效應(yīng)的邏輯操作,但不該同時(shí)具有兩者疏日。
    “從屬效應(yīng)”(side effects)一詞的意思是偿洁,僅僅通過(guò)包含文件,不直接聲明類(lèi)沟优、 函數(shù)和常量等涕滋,而執(zhí)行的邏輯操作。
    “從屬效應(yīng)”包含卻不僅限于:生成輸出净神、直接的 require 或 include何吝、連接外部服務(wù)溉委、修改 ini 配置、拋出錯(cuò)誤或異常爱榕、修改全局或靜態(tài)變量瓣喊、讀或?qū)懳募取?br> 以下是一個(gè)反例,一份包含聲明以及產(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ù)主體部分}

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

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

3. 命名空間和類(lèi)

命名空間以及類(lèi)的命名必須遵循 PSR-0.
根據(jù)規(guī)范藻三,每個(gè)類(lèi)都獨(dú)立為一個(gè)文件,且命名空間至少有一個(gè)層次:頂級(jí)的組織名稱(chēng)(vendor name)跪者。
類(lèi)的命名必須 遵循 StudlyCaps
大寫(xiě)開(kāi)頭的駝峰命名規(guī)范棵帽。
PHP 5.3及以后版本的代碼必須使用正式的命名空間。
例如:

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

5.2.x及之前的版本應(yīng)該使用偽命名空間的寫(xiě)法渣玲,約定俗成使用頂級(jí)的組織名稱(chēng)(vendor name)如 Vendor_
為類(lèi)前綴逗概。

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

4. 類(lèi)的常量、屬性和方法

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

  1. 常量
    類(lèi)的常量中所有字母都必須大寫(xiě)逾苫,詞間以下劃線分隔。參照以下代碼:
<?php
namespace Vendor\Model;
class Foo{
  const VERSION = '1.0'; 
  const DATE_APPROVED = '2012-06-01';
}
  1. 屬性
    類(lèi)的屬性命名可以遵循 大寫(xiě)開(kāi)頭的駝峰式 ($StudlyCaps)枚钓、小寫(xiě)開(kāi)頭的駝峰式 ($camelCase) 又或者是 下劃線分隔式 ($under_score)铅搓,本規(guī)范不做強(qiáng)制要求,但無(wú)論遵循哪種命名方式搀捷,都應(yīng)該在一定的范圍內(nèi)保持一致星掰。這個(gè)范圍可以是整個(gè)團(tuán)隊(duì)、整個(gè)包嫩舟、整個(gè)類(lèi)或整個(gè)方法氢烘。
  2. 方法
    方法名稱(chēng)必須符合 camelCase() 式的小寫(xiě)開(kāi)頭駝峰命名規(guī)范。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末至壤,一起剝皮案震驚了整個(gè)濱河市威始,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌像街,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件晋渺,死亡現(xiàn)場(chǎng)離奇詭異镰绎,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)木西,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)畴栖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人八千,你說(shuō)我怎么就攤上這事吗讶×敲停” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,936評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵照皆,是天一觀的道長(zhǎng)重绷。 經(jīng)常有香客問(wèn)我,道長(zhǎng)膜毁,這世上最難降的妖魔是什么昭卓? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,427評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮瘟滨,結(jié)果婚禮上候醒,老公的妹妹穿的比我還像新娘。我一直安慰自己杂瘸,他們只是感情好倒淫,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,467評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著败玉,像睡著了一般昌简。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上绒怨,一...
    開(kāi)封第一講書(shū)人閱讀 49,785評(píng)論 1 290
  • 那天纯赎,我揣著相機(jī)與錄音,去河邊找鬼南蹂。 笑死犬金,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的六剥。 我是一名探鬼主播晚顷,決...
    沈念sama閱讀 38,931評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼疗疟!你這毒婦竟也來(lái)了该默?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,696評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤策彤,失蹤者是張志新(化名)和其女友劉穎栓袖,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體店诗,經(jīng)...
    沈念sama閱讀 44,141評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡裹刮,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,483評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了庞瘸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片捧弃。...
    茶點(diǎn)故事閱讀 38,625評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出违霞,到底是詐尸還是另有隱情嘴办,我是刑警寧澤,帶...
    沈念sama閱讀 34,291評(píng)論 4 329
  • 正文 年R本政府宣布买鸽,位于F島的核電站涧郊,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏癞谒。R本人自食惡果不足惜底燎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,892評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望弹砚。 院中可真熱鬧双仍,春花似錦、人聲如沸桌吃。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)茅诱。三九已至逗物,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瑟俭,已是汗流浹背翎卓。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留摆寄,地道東北人失暴。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像微饥,于是被迫代替她去往敵國(guó)和親逗扒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,492評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容