PHP PSR-1 基本代碼規範(中文版)

基本代碼規範

本篇規範制定了代碼基本元素的相關標準,
以確保共享的PHP代碼間具備較高程度的技術互通性。php

關鍵詞 「必須」("MUST")、「必定不可/必定不能」("MUST NOT")、「須要」("REQUIRED")、
「將會」("SHALL")、「不會」("SHALL NOT")、「應該」("SHOULD")、「不應」("SHOULD NOT")、
「推薦」("RECOMMENDED")、「能夠」("MAY")和」可選「("OPTIONAL")的詳細描述可參見 RFC 2119 。html

1. 概覽

  • PHP代碼文件必須以 <?php 或 <?= 標籤開始;git

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

  • PHP代碼中應該只定義類、函數、常量等聲明,或其餘會產生 從屬效應 的操做(如:生成文件輸出以及修改.ini配置文件等),兩者只能選其一;segmentfault

  • 命名空間以及類必須符合 PSR 的自動加載規範:PSR-0 或 PSR-4 中的一個;ide

  • 類的命名必須遵循 StudlyCaps 大寫開頭的駝峯命名規範;函數

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

  • 方法名稱必須符合 camelCase 式的小寫開頭駝峯命名規範。編碼

2. 文件

2.1. PHP標籤

PHP代碼必須使用 <?php ?> 長標籤 或 <?= ?> 短輸出標籤;
必定不可使用其它自定義標籤。spa

2.2. 字符編碼

PHP代碼必須且只可以使用不帶BOM的UTF-8編碼。

2.3. 從屬效應(反作用)

一份PHP文件中應該要不就只定義新的聲明,如類、函數或常量等不產生從屬效應的操做,要不就只有會產生從屬效應的邏輯操做,但不應同時具備二者。

「從屬效應」(side effects)一詞的意思是,僅僅經過包含文件,不直接聲明類、
函數和常量等,而執行的邏輯操做。

「從屬效應」包含卻不只限於:生成輸出、直接的 require 或 include、鏈接外部服務、修改 ini 配置、拋出錯誤或異常、修改全局或靜態變量、讀或寫文件等。

如下是一個反例,一份包含聲明以及產生從屬效應的代碼:

<?php// 從屬效應:修改 ini 配置ini_set('error_reporting', E_ALL);// 從屬效應:引入文件include "file.php";// 從屬效應:生成輸出echo "<html>\n";// 聲明函數function foo(){    // 函數主體部分}
相關文章
相關標籤/搜索