PHP代碼規(guī)范

我們寫代碼的時(shí)候厘托,一個(gè)好的編碼規(guī)范,對(duì)我們來(lái)說(shuō)能夠起到很多意向不到的效果:

1稿湿、提高我們的編碼效率铅匹。

2、提高代碼的可讀性饺藤。

3包斑、顯示我們專業(yè)。別人看到了我們的代碼涕俗,發(fā)現(xiàn)整個(gè)代碼的書寫流程都整齊劃一罗丰,瞬間逼格就上去了!劃重點(diǎn)T俟谩C鹊帧!

4元镀、方便團(tuán)隊(duì)協(xié)同工作绍填。大家使用同一的規(guī)范,這樣就消除了五花八分的書寫方式栖疑,同一協(xié)調(diào)讨永!

編碼規(guī)范包含兩大塊,代碼的書寫規(guī)范注釋的書寫規(guī)范遇革。

1.代碼的書寫規(guī)范

文件夾的命名:

文件夾同一使用小寫字母卿闹。如存放控制器的文件夾揭糕,直接命名為controller即可

文件的命名:

如果是類文件的話,那么文件的命名應(yīng)該同類名稱保持一致比原,統(tǒng)一使用大駝峰插佛。如Session.class.php , 對(duì)應(yīng)類名稱為Session,如果是普通的工具腳本量窘,那么統(tǒng)一使用小駝峰,如common.php

類名稱的命名:

類名稱同一使用大駝峰氢拥,Cookie類

方法名的命名:

統(tǒng)一使用小駝峰蚌铜,一般使用 動(dòng)詞 + 名次 的形式來(lái)描述該方法的功能,如sendMessage,發(fā)送短信嫩海。在面向?qū)ο笾卸辏裱瑯拥囊?guī)則,但是個(gè)別地方有所區(qū)別:

變量的命名規(guī)范:

關(guān)于變量叁怪,我們需要多說(shuō)幾點(diǎn):

1.無(wú)論在面向?qū)ο筮€是非面向?qū)ο蟮恼Z(yǔ)法中审葬,變量統(tǒng)一使用小駝峰,如:$workYears奕谭。但是在面向?qū)ο笾杏钟兴煌辆酰琾ublic 、 protected 血柳、 private ,protected或者private屬性的時(shí)候官册,前面加上了 _ 作為區(qū)別

2.如果是常量的話,統(tǒng)一使用大寫难捌,中間使用下劃線進(jìn)行分割膝宁。

3.全局變量,使用大駝峰根吁,前綴加上 _ ,所有的單詞首字母大寫员淫。因?yàn)橹酪粋€(gè)變量的作用域是非常重要的,所以局部變量和全局變量應(yīng)該很明顯的進(jìn)行分開击敌!

示例:$_System_Config;$_Root_Path;

縮進(jìn)符

關(guān)于編碼的縮進(jìn)符號(hào)介返,我們統(tǒng)一使用制表符(tab)縮進(jìn)!也許有的人會(huì)問(wèn)為什么不適用空格縮進(jìn)的呢愚争?原因很簡(jiǎn)單映皆,大部分的編輯器都支持制表符等于多少個(gè)空格,而使用空格就沒(méi)得調(diào)了轰枝!

運(yùn)算符號(hào)

所有的兩元運(yùn)算符號(hào)捅彻,都應(yīng)該前后使用空格進(jìn)行

2.注釋的書寫規(guī)范

很多人說(shuō)好的代碼是不需要注釋的,其實(shí)鞍陨,個(gè)人認(rèn)為這種觀點(diǎn)是錯(cuò)誤的步淹。誰(shuí)也不能保證不接手他人的代碼和他人不接手自己的代碼从隆。多寫注釋,無(wú)論是對(duì)團(tuán)隊(duì)的其他人缭裆,還是對(duì)自己都是非常友好的键闺!

個(gè)人觀點(diǎn),注釋至少有以下幾個(gè)作用:

1.解釋代碼功能 澈驼,提高代碼的可讀性辛燥,提高團(tuán)隊(duì)合作效率。畢竟讀你的注釋要比讀你的代碼要容易的多缝其!

2.保留對(duì)代碼功能的理解挎塌。永遠(yuǎn)不要過(guò)于相信自己的理解力!當(dāng)你思路通暢時(shí)内边,你可以很流暢的實(shí)現(xiàn)某個(gè)功能榴都,但這種流暢可能是因?yàn)槟惝?dāng)時(shí)正處于這種開發(fā)思路中,為了能在再次閱讀這段代碼時(shí)漠其,還能找回當(dāng)初編寫這段代碼的思路嘴高,建議添加注釋!

3.代碼注釋即文檔和屎!程序源代碼是程序文檔的重要組成部分拴驮,當(dāng)我們想著把各種軟件相關(guān)文檔寫注釋的重要性規(guī)范的時(shí)候,不要忘了把軟件里最重要的文檔眶俩,源代碼注釋寫規(guī)范莹汤!

代碼注釋的種類

1、塊注釋颠印,個(gè)人認(rèn)為主要用在了三個(gè)地方纲岭。對(duì)php腳本的描述、對(duì)一個(gè)大的功能模塊的描述线罕、在一行之內(nèi)不能寫完注釋的時(shí)候止潮,也應(yīng)該放在塊注釋中

2、行注釋钞楼,個(gè)人認(rèn)為他是配合塊注釋進(jìn)行工作的喇闸!一般用于描述一個(gè)大的功能模塊的具體細(xì)節(jié)!

下面附上一些php的編程規(guī)范询件,給大家參考下


一燃乍、文件標(biāo)記:

1.所有php文件,其代碼標(biāo)記均采用完整php標(biāo)簽宛琅,不建議使用短標(biāo)簽(短標(biāo)簽容易和xml混淆刻蟹,php從5.4開始默認(rèn)不支持短標(biāo)記)。

2.對(duì)于只有php的代碼文件嘿辟,建議省略結(jié)尾處的‘?>'舆瘪。這是為了防止多余的空格或其他字符影 響到代碼片效。

二、文件和目錄命名

1.程序文件名和目錄名均采用有意義的英文命名英古,不使用拼音和無(wú)意義的字母淀衣,只允許出現(xiàn)字母、數(shù)字召调、下劃線和中劃線字? 符膨桥,同時(shí)必須以‘.php'結(jié)尾(模板文件除外),多個(gè)詞間使用駝峰命名法唠叛。

?? ? 例://類統(tǒng)一采用:DemoTest.class.php

?? ? ? ? ? //接口統(tǒng)一采用:DemoTest.interface.php

?? ? ? ? ? //其他按照各自的方式:demoTest.{style}.php

三国撵、文件目錄結(jié)構(gòu)

規(guī)范的目錄結(jié)構(gòu)有助于團(tuán)隊(duì)協(xié)作開發(fā)和后期維護(hù)。

——app? ? ? ? ? ? //獨(dú)立的應(yīng)用

——class? ? ? ? ? //單個(gè)的類文件玻墅,共用的類文件

——conf/inc? ? //配置文件或目錄

——data? ? ? ? ? //數(shù)據(jù)文件或目錄

——doc? ? ? ? ? //程序相關(guān)文檔

——htdocs? ? ? //document_root

——images? ? ? //所有圖片文件存放路徑

——css? ? ? ? ? ? //css文件

——js? ? ? ? ? ? ? //js文件

——lib? ? ? ? ? ? ? //共用類庫(kù)

——template? ? //模板文件

——tmp? ? ? ? ? ? //臨時(shí)文件目錄

——cache? ? //緩存文件

——session? //SESSION文件

——template_c? ? //編譯后的模板文件

——other

——upload? ? ? //上傳文件

——manage? ? //后臺(tái)管理文件目錄

四、命名規(guī)范

1.變量命名:php中變量區(qū)分大小寫壮虫,一個(gè)有效的變量名由數(shù)字澳厢、字母或下劃線開頭,后面跟任意數(shù)量的字母囚似、數(shù)字剩拢、下劃線。

?? ? a)程序整體以駝峰命名法饶唤,以小寫字母開始徐伐,同時(shí)命名要有意義。(function displayName())

?? ? b)PHP全局變量鍵值兩邊都有‘'募狂,中間用駝峰命名法命名办素。($GLOBAL['beginTime'])

?? ? c)普通變量整體采用駝峰命名法,建議在變量前加表示類型的前綴祸穷。不確定類型的以大寫字符開頭性穿。

?? ? d)函數(shù)名要盡量有意義,盡量縮寫雷滚。

2.類及接口命名:

?? ? a)以大寫字母開頭需曾。

?? ? b)多個(gè)單詞組成的變量名,單詞之間不用間隔祈远,各個(gè)單詞首字母大寫呆万。

?? ? c)類名與類文件名保持一致。

?? ? d)程序中所有的類名唯一车份。

?? ? e)抽象類應(yīng)以Abstract開頭谋减。

?? ? 接口命名規(guī)則:

?? ? ? ? i)采用和類相同的命名規(guī)則,但在其命名前加‘i'字符躬充,表示接口逃顶。

?? ? ? ? ii)盡量保持和實(shí)現(xiàn)它的類名一致讨便。

3.數(shù)據(jù)庫(kù)命名:在數(shù)據(jù)庫(kù)相關(guān)命名中,一律不出現(xiàn)大寫以政。

?? ? a)表名均使用小寫字母霸褒。

?? ? b)表名使用同一的前綴且前綴不能為空。

?? ? c)對(duì)于多個(gè)單詞組成的表名盈蛮,使用‘_'間隔废菱。

?? ? d)表字段命名規(guī)則。

?? ? ? ? ? ? i)全部使用小寫字母抖誉。

?? ? ? ? ? ? ii)多個(gè)單詞不用下劃線分割殊轴。

?? ? ? ? ? ? iii)給常用字段加上表名首字母做前綴。

?? ? ? ? ? ? iv)避免使用關(guān)鍵字和保留字袒炉。

五旁理、注釋規(guī)范

1.程序注釋:寫在代碼前面而不是后面,單行代碼按照習(xí)慣寫在代碼尾部我磁;大段注釋采用/**/的方式孽文,通常為文件或函數(shù)的頂部,代碼內(nèi)部使用'//'夺艰;注釋不宜太多芋哭;代碼注釋應(yīng)該描述為什么而不是做什么,給代碼閱讀者提供最主要的信息郁副。

2.文件注釋:文件注釋一般放在文件的頂部减牺,包括本程序的描述、作者存谎、項(xiàng)目名稱拔疚、文件名稱、時(shí)間日期愕贡、版本信息草雕、重要的使用說(shuō)明(類的調(diào)用,注意事項(xiàng)等)固以。版本更改要修改版本號(hào)墩虹,并加上mofify注釋。

3.類和接口注釋:按照一般的習(xí)慣憨琳,一個(gè)文件只包含一個(gè)類诫钓。

4.方法和函數(shù)注釋:方法和函數(shù)的注釋寫在前面,通常需要表明信息的主要可見性篙螟、參數(shù)類型和返回值類型菌湃。

?? ?

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市遍略,隨后出現(xiàn)的幾起案子惧所,更是在濱河造成了極大的恐慌骤坐,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,627評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件下愈,死亡現(xiàn)場(chǎng)離奇詭異纽绍,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)势似,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門拌夏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人履因,你說(shuō)我怎么就攤上這事障簿。” “怎么了栅迄?”我有些...
    開封第一講書人閱讀 169,346評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵站故,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我毅舆,道長(zhǎng)世蔗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,097評(píng)論 1 300
  • 正文 為了忘掉前任朗兵,我火速辦了婚禮,結(jié)果婚禮上顶滩,老公的妹妹穿的比我還像新娘余掖。我一直安慰自己,他們只是感情好礁鲁,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,100評(píng)論 6 398
  • 文/花漫 我一把揭開白布盐欺。 她就那樣靜靜地躺著,像睡著了一般仅醇。 火紅的嫁衣襯著肌膚如雪冗美。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,696評(píng)論 1 312
  • 那天析二,我揣著相機(jī)與錄音粉洼,去河邊找鬼。 笑死叶摄,一個(gè)胖子當(dāng)著我的面吹牛属韧,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蛤吓,決...
    沈念sama閱讀 41,165評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼宵喂,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了会傲?” 一聲冷哼從身側(cè)響起锅棕,我...
    開封第一講書人閱讀 40,108評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤拙泽,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后裸燎,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體顾瞻,經(jīng)...
    沈念sama閱讀 46,646評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,709評(píng)論 3 342
  • 正文 我和宋清朗相戀三年顺少,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了朋其。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,861評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡脆炎,死狀恐怖梅猿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情秒裕,我是刑警寧澤袱蚓,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站几蜻,受9級(jí)特大地震影響喇潘,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜梭稚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,196評(píng)論 3 336
  • 文/蒙蒙 一颖低、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧弧烤,春花似錦忱屑、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至急波,卻和暖如春从铲,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背澄暮。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工名段, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人泣懊。 一個(gè)月前我還...
    沈念sama閱讀 49,287評(píng)論 3 379
  • 正文 我出身青樓吉嫩,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親嗅定。 傳聞我的和親對(duì)象是個(gè)殘疾皇子自娩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,860評(píng)論 2 361

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