摘要:開發(fā)規(guī)范整理代碼樣式規(guī)范編碼基本規(guī)范代碼必須遵守。申明相關(guān)規(guī)范命名空間申明和使用在聲明下面必須有一個空行,并且聲明代碼塊下面也必須有一個空行空格空格類的申明類的左花括號必須放到下一行,右花括號必須放在類主體的下一行。
PHP 開發(fā)規(guī)范整理
代碼樣式規(guī)范
編碼基本規(guī)范
a、代碼必須遵守 PSR-1。
b、文件編碼Unicode (UTF-8) 編碼保存。同時不要使用 字節(jié)序標記(BOM)
c、代碼必須使用4個空格的縮進,而不是制表符。
d、一行代碼長度不應(yīng)硬性限制;軟限制必須為120個字符;也應(yīng)當是80個字符或者更少。
2、申明相關(guān)規(guī)范
2.1 命名空間申明和使用
a、 ##在namespace聲明下面必須有一個空行,并且use聲明代碼塊下面也必須有一個空行
namespace frontendcontrollers;
.....空格
use Yii;
.....空格
2.2 類的申明
a、類的左花括號必須放到下一行,右花括號必須放在類主體的下一行。
b、方法的左花括號必須放在下一行,右花括號必須放在方法主體下面。
c、術(shù)語“類”指所有的類,接口( interface ) 抽象類( abstract ) 和 特性( traits )
class DbMysql
{
.....代碼
}
interface DbMysql
{
.....代碼
}
abstract DbMysql
{
.....代碼
}
traits DbMysql
{
.....代碼
}
2.3 類的擴展和繼承
a、一個類的extends和implements關(guān)鍵詞必須和類名在同一行。
b、類的左花括號必須放在下面自成一行;右花括號必須放在類主體的后面自成一行。
class ClassName extends ParentClass implements ArrayAccess, Countable
{
.....代碼
}
c、implements一個列表可以被拆分為多個有一次縮進的后續(xù)行。如果這么做,列表的第一項必須要放在下一行,并且每行必須只有一個接口。
class ClassName extends ParentClass implements
ArrayAccess,
Countable,
Serializable
{
.....代碼
}
2.4 方法申明
a、所有的屬性和方法必須有可見性(譯者注:Public, Protect, Private)聲明
b、在參數(shù)列表中,逗號之前不可有空格,逗號之后必須要有一個空格。
c、方法中有默認值的參數(shù)必須放在參數(shù)列表的最后面。
class DbMysql
{
public function getUser($arg1, &$arg2, $arg3 = [])
{
.....代碼
}
}
b、abstract和final聲明必須在可見性之前;
class DbMysql
{
final public function getUser()
{
.....代碼
}
}
c、static聲明必須在可見性之后
靜態(tài) static 方法應(yīng)該聲明其作用域,且不應(yīng)該再被聲明為 private 私有,而應(yīng)該為 protected 或者public
如果只是不想被子類繼承,則應(yīng)該用 final 聲明它們
class DbMysql
{
public static function getUser()
{
.....代碼
}
}
3、命名規(guī)范
3.1 普通變量
a. 所有字母都使用小寫;
b. 對于一個變量使用多個單詞的,使用’_"作為每個詞的間隔
例如:$base_dir、$red_rose_price等
3.2 局部變量
a. 所有字母使用小寫;
b. 變量使用’"開頭;
c. 多個單詞組成的局部變量名使用’"作為每個詞間的間隔
例子:$_base_dir、$_red_rose_price等。
3.3 全局變量
全局變量應(yīng)該帶前綴’g",知道一個變量的作用域是非常重要的
例如
global $g_log_level;
global $g_log_path;
3.4 全局常量
a. 所有字母使用大寫
b. 全局變量多個單詞間使用’_"作為間隔
例子:$BASE_DIR、$RED_ROSE_PRICE等
3.5 函數(shù)
a. 所有字母都使用小寫
b. 對于一個變量使用多個單詞的,使用’_"作為每個詞的間隔
c. 函數(shù)的命名建議使用動詞+名詞的方式,如get_user_img。
完成一組功能的函數(shù)放到一個文件中,存放函數(shù)的文件采用function_name.func.php命名
3.6 類
a. 以大寫字母開頭;
b. 多個單詞組成的變量名,單詞之間不用間隔,各個單詞首字母大寫。
例子:class MyClass 或class DbOracle等。
3.7 方法
a. 首字母小寫;
b. 多個單詞間不使用間隔,除第一個單詞外,其他單詞首字母大寫
例子:function myFunction ()或function myDbOracle ()等
4、控制結(jié)構(gòu)申明
4.1. if,elseif,else
a、一個if結(jié)構(gòu)看起來應(yīng)該像下面這樣。注意括號,空格,花括號的位置;
b、并且else和elseif和前一個主體的右花括號在同一行。
if ($expr1) {
// if body
} elseif ($expr2) {
// elseif body
} else {
// else body;
}
關(guān)鍵詞elseif應(yīng)該替代else if使用以保持所有的控制關(guān)鍵詞像一個單詞。
4.2. switch,case
a、一個switch結(jié)構(gòu)看起來應(yīng)該像下面這樣。注意括號,空格和花括號。
b、case語句必須從switch處縮進,并且break關(guān)鍵字(或其他中止關(guān)鍵字)必須和case主體縮進在同級。
c、如果一個非空的case主體往下落空則必須有一個類似// no break的注釋。
switch ($expr) {
case 0:
echo "First case, with a break";
break;
case 1:
echo "Second case, which falls through";
// no break
case 2:
case 3:
case 4:
echo "Third case, return instead of break";
return;
default:
echo "Default case";
break;
}
4.3. while,do while
a、一個while語句看起來應(yīng)該像下面這樣。注意括號,空格和花括號的位置。
while ($expr) {
// structure body
}
b、同樣的,一個do while語句看起來應(yīng)該像下面這樣。注意括號,空格和花括號的位置。
do {
// structure body;
} while ($expr);
4.4. for
a、一個for語句看起來應(yīng)該像下面這樣。注意括號,空格和花括號的位置。
for ($i = 0; $i < 10; $i++) {
// for body
}
4.5. foreach
a、一個foreach語句看起來應(yīng)該像下面這樣。注意括號,空格和花括號的位置。
foreach ($iterable as $key => $value) {
// foreach body
}
4.6. try, catch
a、一個try catch語句看起來應(yīng)該像下面這樣。注意括號,空格和花括號的位置。
try {
// try body
} catch (FirstExceptionType $e) {
// catch body
} catch (OtherExceptionType $e) {
// catch body
}
5、編碼習(xí)慣
5.1、變量使用
a.所有的變量均需要先申明后使用
b.對于數(shù)組或?qū)ο螅谑褂靡粋€不確定的key時,首先進行isset()的判斷,然后再使用
例子:$var = ""; isset($val) ? $val : "";
5.2、變量的輸入輸出
a.不推薦直接使用$_GET、$_POST或者$_REQUEST獲取值
b.所有的輸入輸出都必須使用框架封裝的方法來實現(xiàn)
5.3、字符串相關(guān)
a.字符串盡量使用單引號
b.如果字符串中需要使用變量,例如:$val = "tips:{$title}";
6. 閉包( 參考 )
閉包在聲明時function關(guān)鍵詞之后必須有一個空格,并且use之前也需要一個空格。
左花括號必須在同一行,右花括號必須在主體的下一行。
參數(shù)列表和變量列表的左括號之后不可有空格,其右括號之前也不可有空格。
在參數(shù)列表和變量列表中,逗號之前不可有空格,逗號之后必須有空格。
閉包帶默認值的參數(shù)必須放在參數(shù)列表后面。
一個閉包聲明看起來應(yīng)該像下面這樣。注意括號,空格和花括號的位置。
$closureWithArgs = function ($arg1, $arg2) {
// body
};
$closureWithArgsAndVars = function ($arg1, $arg2) use ($var1, $var2) {
// body
};
參數(shù)和變量列表可以被分成多個帶一次縮進的后續(xù)行。如果這么做,列表的第一項必須放在下一行,并且一行必須只放一個參數(shù)或變量。
當最終列表(不管是參數(shù)還是變量)被分成多行,右括號和左花括號必須夾帶一個空格放在一起自成一行。
下面是一個參數(shù)和變量列表被分割成多行的示例。
$longArgs_noVars = function (
$longArgument,
$longerArgument,
$muchLongerArgument
) {
// body
};
$noArgs_longVars = function () use (
$longVar1,
$longerVar2,
$muchLongerVar3
) {
// body
};
$longArgs_longVars = function (
$longArgument,
$longerArgument,
$muchLongerArgument
) use (
$longVar1,
$longerVar2,
$muchLongerVar3
) {
// body
};
$longArgs_shortVars = function (
$longArgument,
$longerArgument,
$muchLongerArgument
) use ($var1) {
// body
};
$shortArgs_longVars = function ($arg) use (
$longVar1,
$longerVar2,
$muchLongerVar3
) {
// body
};
注意如果在函數(shù)或者方法中把閉包作為一個參數(shù)調(diào)用,如上格式規(guī)則同樣適用。
$foo->bar(
$arg1,
function ($arg2) use ($var1) {
// body
},
$arg3
);
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/21841.html
摘要:本文目的是通過自己寫的一個的簡單的庫花密密碼生成工具,來學(xué)習(xí)我認為的庫開發(fā)的一些規(guī)范,以及上持續(xù)構(gòu)建你的項目的一些方法。給自己的項目開啟持續(xù)構(gòu)建。包發(fā)布以及當你的代碼完成后,測試完成后。 本文目的是通過自己寫的一個php的簡單的庫(花密密碼生成工具), 來學(xué)習(xí)我認為的php庫開發(fā)的一些規(guī)范,以及github上持續(xù)構(gòu)建你的項目的一些方法。其實是為了顯示下邊一系列的的徽章 showImg(...
摘要:今天這篇分享將簡單地梳理一下規(guī)范,并介紹一個代碼檢查工具,結(jié)合以及進行實踐。目前流行的一些規(guī)范是的簡寫,由組織制定的規(guī)范,是開發(fā)的實踐標準。目前已表決通過了套標準,已經(jīng)得到大部分框架的支持和認可。 > 作為一個新手,寫出規(guī)范的代碼也是一門必修課,除了閱讀相應(yīng)的代碼規(guī)范文檔之外,充分利用相關(guān)的工具能使得進階之路事半功倍。今天這篇分享將簡單地梳理一下 PHP 規(guī)范,并介紹一個代碼檢查工具 ...
摘要:本規(guī)范只針對開發(fā)過程中編碼的規(guī)范,對于開發(fā)項目中文件目錄數(shù)據(jù)庫等方面的規(guī)范,將不重點涉及。本規(guī)范包含了開發(fā)時程序編碼中命名規(guī)范代碼縮進規(guī)則控制結(jié)構(gòu)函數(shù)調(diào)用函數(shù)定義注釋包含代碼標記文件頭的注釋塊標記樣例常量命名等方面的規(guī)則。 第一章 編碼規(guī)范 為了更好的提高技術(shù)部的工作效率,保證開發(fā)的有效性和合理性,并可最大程度的提高程序代碼的可讀性和可重復(fù)利用性,指定此規(guī)范。開發(fā)團隊根據(jù)自己的實際情...
摘要:標準規(guī)范簡介是的簡寫,由組織制定的規(guī)范,是開發(fā)的實踐標準。具體標準有有了統(tǒng)一編碼風格規(guī)范,更有利于查看和學(xué)習(xí)各個框架或類庫,不不需要每次都適應(yīng)新的編碼風格。同時在開發(fā)團隊內(nèi)部使用統(tǒng)一的編碼規(guī)范更有利于代碼審查版本控制團隊內(nèi)部交流。 PHP 標準規(guī)范 PSR PSR 簡介 PSR 是 PHP Standard Recommendations 的簡寫,由 PHP FIG 組織制定的 PHP...
摘要:的使命是實現(xiàn)框架之間的互操作性。個人和官方都認為開發(fā)者應(yīng)該遵循更為嚴格的代碼標準,在現(xiàn)代的生態(tài)系統(tǒng)中,風格統(tǒng)一,可以更好的讓其他開發(fā)者理解代碼。記錄的消息用于診斷檢查和排除應(yīng)用中的操作穩(wěn)定性和性能方面的問題。 原文是在我自己博客中,小伙伴也可以點閱讀原文進行跳轉(zhuǎn)查看,還有好聽的背景音樂噢~ ????PSR是PHP Standards Recommendation的簡稱,意為PHP推薦標...
摘要:為什么需要編碼規(guī)范為了提高工作效率,保證開發(fā)的有效性和合理性。在文件編碼中,選擇推薦在換行符中,選擇推薦文件命名程序的文件名和目錄名都采用有意義的英文命名。最后最后說的是,本規(guī)范不是強制,也不是標準。回復(fù)編碼規(guī)范即可。 為什么需要編碼規(guī)范? 為了提高工作效率,保證開發(fā)的有效性和合理性。 為了提高代碼可讀性和可重復(fù)利用性,從而節(jié)約溝通成本。 本文主要參考了 PEAR 規(guī)范,并進行適當...
閱讀 2219·2021-11-15 11:36
閱讀 1383·2021-10-14 09:42
閱讀 4208·2021-09-30 09:52
閱讀 1717·2021-09-24 10:24
閱讀 967·2021-09-02 09:56
閱讀 2685·2019-08-30 13:11
閱讀 3060·2019-08-30 13:06
閱讀 947·2019-08-30 12:56