PHP符合PSR編程規(guī)范的實(shí)例分享
前言
關(guān)于開發(fā)標(biāo)準(zhǔn)這塊,可以說一直都是風(fēng)格迥異,各家都有各家的玩法,民間更是個(gè)人玩?zhèn)€人的。目前我們國(guó)內(nèi)比較出名的幾個(gè)框架(Yii,Laravel) 都已經(jīng)支持Composer并且加入了PHP-FIG(php框架程序組)。
其中Composer的自動(dòng)加載就支持PHP-FIG指定的PSR-0 和 PSR-4 規(guī)范來實(shí)現(xiàn)自動(dòng)加載機(jī)制,并且Composer推薦使用PSR-4
PHP-FIG
這是一個(gè)自愿非正式的機(jī)構(gòu),但是就目前對(duì)我們的影響來看,可能都已經(jīng)默認(rèn)為一個(gè)公信組織了,的的確確制定了不少非常好的規(guī)范
目前從官網(wǎng)看,已經(jīng)投票( http://www.php-fig.org/psr/ )通過的有7個(gè)大的規(guī)范了
- PSR-0 自動(dòng)加載規(guī)范 ( 官方已廢棄,主要是php5.3以前沒有命名空間 )
- PSR-1 編碼規(guī)范
- PSR-2 編碼風(fēng)格推薦
- PSR-3 日志接口
- PSR-4 改進(jìn)的自動(dòng)加載規(guī)范( 官方推薦 ,規(guī)范更簡(jiǎn)潔調(diào)理清晰了)
- PSR-6 緩存接口
- PSR-7 HTTP消息接口
實(shí)例
<?php
namespace Standard; // 頂部命名空間
// 空一行
use Test\TestClass;//use引入類
/**
* 類描述
*
* 類名必須大寫開頭駝峰.
*/
abstract class StandardExample // {}必須換行
{
/**
* 常量描述.
*
* @var string
*/
const THIS_IS_A_CONST = ''; // 常量全部大寫下劃線分割
/**
* 屬性描述.
*
* @var string
*/
public $nameTest = ''; // 屬性名稱建議開頭小寫駝峰
// 成員屬性必須添加public(不能省略), private, protected修飾符
/**
* 屬性描述.
*
* @var string
*/
private $_privateNameTest = ''; // 類私有成員屬性,【個(gè)人建議】下劃線小寫開頭駝峰
/**
* 構(gòu)造函數(shù).
*
* 構(gòu)造函數(shù)描述
*
* @param string $value 形參名稱/描述
*/
public function __construct($value = '')// 成員方法必須添加public(不能省略), private, protected修飾符
{// {}必須換行
$this->nameTest = new TestClass();
// 鏈?zhǔn)讲僮?
$this->nameTest->functionOne()
->functionTwo()
->functionThree();
// 一段代碼邏輯執(zhí)行完畢 換行
// code...
}
/**
* 成員方法名稱.
*
* 成員方法描述
*
* @param string $value 形參名稱/描述
*
* @return 返回值類型 返回值描述
* 返回值類型:string,array,object,mixed(多種,不確定的),void(無返回值)
*/
public function testFunction($value = '')// 成員方法必須小寫開頭駝峰
{
// code...
}
/**
* 成員方法名稱.
*
* 成員方法描述
*
* @param string $value 形參名稱/描述
*
* @return 返回值類型 返回值描述
*/
private function _privateTestFunction($value = '')// 私有成員方法【個(gè)人建議】下劃線小寫開頭駝峰
{
// code...
}
/**
* 成員方法名稱.
*
* 成員方法描述
*
* @param string $value 形參名稱/描述
*
* @return 返回值類型 返回值描述
*/
public static function staticFunction($value = '')// static位于修飾符之后
{
// code...
}
/**
* 成員方法名稱.
*
* 成員方法描述
*
* @param string $value 形參名稱/描述
*
* @return 返回值類型 返回值描述
*/
abstract public function abstractFunction($value = ''); // abstract位于修飾符之前
/**
* 成員方法名稱.
*
* 成員方法描述
*
* @param string $value 形參名稱/描述
*
* @return 返回值類型 返回值描述
*/
final public function finalFunction($value = '')// final位于修飾符之前
{
// code...
}
/**
* 成員方法名稱.
*
* 成員方法描述
*
* @param string $valueOne 形參名稱/描述
* @param string $valueTwo 形參名稱/描述
* @param string $valueThree 形參名稱/描述
* @param string $valueFour 形參名稱/描述
* @param string $valueFive 形參名稱/描述
* @param string $valueSix 形參名稱/描述
*
* @return 返回值類型 返回值描述
*/
public function tooLangFunction(
$valueOne = '', // 變量命名可小寫開頭駝峰或者下劃線命名,個(gè)人那習(xí)慣,據(jù)說下劃線可讀性好
$valueTwo = '',
$valueThree = '',
$valueFour = '',
$valueFive = '',
$valueSix = '')// 參數(shù)過多換行
{
if ($valueOne === $valueTwo) {// 控制結(jié)構(gòu)=>后加空格,同{一行,(右邊和)左邊不加空格
// code...
}
switch ($valueThree) {
case 'value':
// code...
break;
default:
// code...
break;
}
do {
// code...
} while ($valueFour <= 10);
while ($valueFive <= 10) {
// code...
}
for ($i=0; $i < $valueSix; $i++) {
// code...
}
}
}
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
PHP使用pdo連接access數(shù)據(jù)庫(kù)并循環(huán)顯示數(shù)據(jù)操作示例
這篇文章主要介紹了PHP使用pdo連接access數(shù)據(jù)庫(kù)并循環(huán)顯示數(shù)據(jù)操作,結(jié)合實(shí)例形式較為詳細(xì)的分析了php使用pdo進(jìn)行access數(shù)據(jù)庫(kù)連接、查詢、執(zhí)行sql語句、預(yù)處理等相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2018-06-06
PHP+Ajax實(shí)現(xiàn)的博客文章添加類別功能示例
這篇文章主要介紹了PHP+Ajax實(shí)現(xiàn)的博客文章添加類別功能,結(jié)合實(shí)例形式分析了php+ajax實(shí)現(xiàn)的數(shù)據(jù)交互、數(shù)據(jù)庫(kù)連接、查詢等相關(guān)操作技巧,需要的朋友可以參考下2018-03-03
php實(shí)現(xiàn)的DateDiff和DateAdd時(shí)間函數(shù)代碼分享
這篇文章主要介紹了php實(shí)現(xiàn)的DateDiff和DateAdd時(shí)間函數(shù)代碼分享,DateDiff用來計(jì)算兩個(gè)時(shí)間的間隔,DateAdd用來對(duì)兩個(gè)時(shí)間進(jìn)行相加,需要的朋友可以參考下2014-08-08
百度工程師講PHP函數(shù)的實(shí)現(xiàn)原理及性能分析(二)
這篇文章主要介紹了百度工程師講PHP函數(shù)的實(shí)現(xiàn)原理及性能分析(二),本文講解了類方法、性能對(duì)比、內(nèi)置函數(shù)和用戶函數(shù)性能對(duì)比等內(nèi)容,需要的朋友可以參考下2015-05-05
PHP連接MSSQL時(shí)nvarchar字段長(zhǎng)度被截?cái)酁?55的解決方法
這篇文章主要介紹了PHP連接MSSQL時(shí)nvarchar字段長(zhǎng)度被截?cái)酁?55的解決方法,可通過CAST數(shù)據(jù)類型轉(zhuǎn)換來解決,是非常實(shí)用的技巧,需要的朋友可以參考下2014-12-12

