php代码规范的书籍,php基本代码规范——PSR-1
基本代碼規(guī)范
本節(jié)我們將會討論一些基本的代碼規(guī)范問題,以此作為將來討論更高級別的代碼分享和技術(shù)互用的基礎(chǔ)。
RFC 2119中的必須(MUST),不可(MUST NOT),建議(SHOULD),不建議(SHOULD NOT),可以/可能(MAY)等關(guān)鍵詞將在本節(jié)用來做一些解釋性的描述。
1. 概述
源文件必須只使用 <?php 和 <?= 這兩種標(biāo)簽。
源文件中php代碼的編碼格式必須只使用不帶字節(jié)順序標(biāo)記(BOM)的UTF-8。
一個(gè)源文件建議只用來做聲明(類(class),函數(shù)(function),常量(constant)等)或者只用來做一些引起副作用的操作(例如:輸出信息,修改.ini配置等),但不建議同時(shí)做這兩件事。
命名空間(namespace)和類(class) 必須遵守PSR-0標(biāo)準(zhǔn)。
類名(class name) 必須使用駱駝式(StudlyCaps)寫法 (譯者注:駝峰式(cameCase)的一種變種,后文將直接用StudlyCaps表示)。
類(class)中的常量必須只由大寫字母和下劃線(_)組成。
方法名(method name) 必須使用駝峰式(cameCase)寫法(譯者注:后文將直接用camelCase表示)。
2. 文件
2.1. PHP標(biāo)簽
PHP代碼必須只使用長標(biāo)簽(<?php ?>)或者短輸出式標(biāo)簽(= ?>);而不可使用其他標(biāo)簽。
2.2. 字符編碼
PHP代碼的編碼格式必須只使用不帶字節(jié)順序標(biāo)記(BOM)的UTF-8。
2.3. 副作用
一個(gè)源文件建議只用來做聲明(類(class),函數(shù)(function),常量(constant)等)或者只用來做一些引起副作用的操作(例如:輸出信息,修改.ini配置等),但不建議同時(shí)做這兩件事。
短語副作用(side effects)的意思是 在包含文件時(shí) 所執(zhí)行的邏輯與所聲明的類(class),函數(shù)(function),常量(constant)等沒有直接的關(guān)系。
副作用(side effects)包含但不局限于:產(chǎn)生輸出,顯式地使用require或include,連接外部服務(wù),修改ini配置,觸發(fā)錯誤或異常,修改全局或者靜態(tài)變量,讀取或修改文件等等
下面是一個(gè)既包含聲明又有副作用的示例文件;即應(yīng)避免的例子:
// 副作用:修改了ini配置
ini_set('error_reporting', E_ALL);
// 副作用:載入了文件
include "file.php";
// 副作用:產(chǎn)生了輸出
echo "\n";
// 聲明
function foo()
{
// 函數(shù)體
}
下面是一個(gè)僅包含聲明的示例文件;即應(yīng)提倡的例子:
// 聲明
function foo()
{
// 函數(shù)體
}
// 條件式聲明不算做是副作用
if (! function_exists('bar')) {
function bar()
{
// 函數(shù)體
}
}
3. 空間名(namespace)和類名(class name)
命名空間(namespace)和類(class)必須遵守 PSR-0.
這意味著一個(gè)源文件中只能有一個(gè)類(class),并且每個(gè)類(class)至少要有一級空間名(namespace):即一個(gè)頂級的組織名(vendor name)。
類名(class name) 必須使用StudlyCaps寫法。
PHP5.3之后的代碼必須使用正式的命名空間(namespace)
例子:
// PHP 5.3 及之后:
namespace Vendor\Model;
class Foo
{
}
PHP5.2.x之前的代碼建議用偽命名空間Vendor_作為類名(class name)的前綴
// PHP 5.2.x 及之前:
class Vendor_Model_Foo
{
}
4. 類的常量、屬性和方法
術(shù)語類(class)指所有的類(class),接口(interface)和特性(trait)
4.1. 常量
類常量必須只由大寫字母和下劃線(_)組成。
例子:
namespace Vendor\Model;
class Foo
{
const VERSION = '1.0';
const DATE_APPROVED = '2012-06-01';
}
4.2. 屬性
本指南中故意不對$StulyCaps,$camelCase或者$unser_score中的某一種風(fēng)格作特別推薦,完全由讀者依據(jù)個(gè)人喜好決定屬性名的命名風(fēng)格。
但是不管你如何定義屬性名,建議在一個(gè)合理的范圍內(nèi)保持一致。這個(gè)范圍可能是組織(vendor)級別的,包(package)級別的,類(class)級別的,或者方法(method)級別的。
4.3. 方法
方法名則必須使用camelCase()風(fēng)格來聲明。
《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的php代码规范的书籍,php基本代码规范——PSR-1的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java商城管理系统ssm_基于SSM+
- 下一篇: php 原生开发,四个优秀php原生开发