1. 不要使用mysql_函數(shù)
這一天終于來了浅萧,從此你不僅僅“不應(yīng)該”使用mysql_函數(shù)。PHP 7 已經(jīng)把它們從核心中全部移除了整胃,也就是說你需要遷移到好得多的mysqli_函數(shù)巢掺,或者更靈活的 PDO 實(shí)現(xiàn)关霸。
2. 不要編寫垃圾代碼
這一條可能易于理解丑罪,但是會(huì)變得越來越重要荚板,因?yàn)?PHP 7 的速度提升可能會(huì)隱藏你的一些問題凤壁。不要僅僅滿足于你的站點(diǎn)速度吩屹,因?yàn)檫w移到 PHP 7 才讓它變快跪另。
為了理解速度有多重要,以及如何把事情做得更好煤搜,請(qǐng)看一看我們的文章速度優(yōu)化入門指南免绿。
作為一名開發(fā)者,你應(yīng)該總是確保按需加載腳本擦盾,盡可能連接它們嘲驾,編寫高效的數(shù)據(jù)庫(kù)查詢,盡可能使用緩存迹卢,以及其它辽故。
3. 不要在文件末尾使用 PHP 閉合標(biāo)簽
你可以看一看,當(dāng)一個(gè)文件以 PHP 代碼結(jié)尾時(shí)腐碱,WordPress 多數(shù)核心代碼都把末尾的 PHP 標(biāo)簽去掉了誊垢。實(shí)際上,Zend 框架特別禁止了它症见。PHP 并不需要文件末尾的閉合標(biāo)簽喂走,并且我們可以通過去掉它來保證不會(huì)在后面添加任何的空白字符。
4. 不要做不必要的引用傳遞
我個(gè)人不喜歡引用傳遞谋作。我知道有時(shí)候它很實(shí)用芋肠,但是其它情況下它使代碼變得難懂,并且更難預(yù)測(cè)結(jié)果遵蚜。
據(jù)說一些人認(rèn)為它使代碼運(yùn)行更快帖池,但是根據(jù)一些 PHP 高級(jí)程序員所說,這并不正確吭净。
說明引用為什么不好的一個(gè)例子是碘裕,PHP 內(nèi)建了shuffle()和sort()。它們修改原始數(shù)組攒钳,而不是返回處理后的數(shù)組帮孔,這很不合邏輯。
5. 不要在循環(huán)中執(zhí)行查詢
在循環(huán)中執(zhí)行查詢非常浪費(fèi)不撑。它給你的系統(tǒng)施加不必要的壓力文兢,并且可能能夠在循環(huán)外部更快獲得相同結(jié)果。當(dāng)我遇到需要這樣的情況時(shí)焕檬,我通常會(huì)使用兩個(gè)分離的查詢來解決問題姆坚,我會(huì)使用它們來構(gòu)建數(shù)據(jù)數(shù)組。之后我會(huì)遍歷數(shù)組实愚,并不需要在這個(gè)過程中執(zhí)行查詢兼呵。
由于
WordPress 適用于這里兔辅,它可能有一些例外。雖然get_post_meta()
會(huì)從數(shù)據(jù)庫(kù)獲取大量數(shù)據(jù)击喂,如果你正在遍歷某個(gè)特殊博文的元數(shù)據(jù)你可以在循環(huán)中使用它维苔。這是因?yàn)楫?dāng)你第一次調(diào)用它的時(shí)候,WordPress實(shí)際上會(huì)獲取所有元數(shù)據(jù)并緩存它們懂昂。后續(xù)的調(diào)用使用這些緩存數(shù)據(jù)介时,沒有數(shù)據(jù)庫(kù)的調(diào)用。
弄懂這些的最佳方式是閱讀函數(shù)文檔凌彬,以及使用類似Query Monitor的工具沸柔。
6. 不要在 SQL 查詢中使用*
當(dāng)然,這個(gè)更像 MySQL 的問題铲敛,但是我們習(xí)慣在 PHP 中編寫 SQL 代碼褐澎,所以都差不多。無(wú)論如何伐蒋,如果可以避免的話工三,不要在 SQL 查詢里使用通配符,尤其是數(shù)據(jù)庫(kù)有很多列的時(shí)候咽弦。
你應(yīng)該明確指定需要哪些行徒蟆,并且僅僅獲取它們。這有助于減少所用資源型型,保護(hù)數(shù)據(jù)段审,以及讓事情變得盡可能清晰。
對(duì)于 SQL闹蒜,你需要了解所有可用的函數(shù)寺枉,并且盡可能測(cè)試其速度。在計(jì)算均值绷落、求和或計(jì)算類似數(shù)值時(shí)姥闪,要使用 SQL 函數(shù)而不是 PHP 函數(shù)。如果你不確定某個(gè)查詢的速度砌烁,測(cè)試它并且嘗試一些其它的編譯 -- 之后使用最好的那個(gè)筐喳。
7. 不要信任用戶輸入
信任用戶輸入是不明智的。始終校驗(yàn)函喉、過濾避归、轉(zhuǎn)義、檢查并留好退路管呵。用戶數(shù)據(jù)存在三個(gè)問題:我們開發(fā)者并沒有考慮每種可能性梳毙,它通常不正確,以及它可能是蓄意破壞捐下。
經(jīng)過周密考慮的系統(tǒng)可以防護(hù)這些威脅账锹。要確保使用類似filter_var()的內(nèi)建函數(shù)檢查適當(dāng)?shù)闹得纫担约霸谔幚頂?shù)據(jù)庫(kù)時(shí)轉(zhuǎn)義(或預(yù)編譯)。
WordPress 擁有一些函數(shù)來解決問題奸柬。詳見文章校驗(yàn)生年、轉(zhuǎn)義和過濾用戶數(shù)據(jù)。
8. 不要故作聰明
你的目標(biāo)應(yīng)該是編寫優(yōu)雅的代碼鸟缕,來更清晰地表達(dá)你的意圖晶框。你可能能夠通過將任何東西縮短為一個(gè)單詞的變量排抬,使用多層的三元邏輯懂从,以及其它手段,從每個(gè)頁(yè)面中優(yōu)化 0.01 秒蹲蒲。但這只會(huì)給你和你周圍的人產(chǎn)生大麻煩番甩。
合理命名變量,為代碼編寫文檔届搁,優(yōu)先選擇清晰而不是簡(jiǎn)潔缘薛。甚至還可以更好,使用標(biāo)準(zhǔn)的面向?qū)ο蟠a卡睦,它本身或多或少就是文檔宴胧,不需要一大堆內(nèi)聯(lián)數(shù)值。
9. 不要重新發(fā)明輪子
PHP 到現(xiàn)在為止有很長(zhǎng)時(shí)間了表锻,網(wǎng)站被造出來的時(shí)間更長(zhǎng)恕齐。很可能無(wú)論你需要造出什么,一些人之前早就造出來了瞬逊。不要害怕向他人尋求支持显歧,Github是你的好朋友,Composer也是确镊,Packagist也是士骤。
從日志工具到調(diào)色工具,從性能分析器到單元測(cè)試框架蕾域,從 Mailchimp API 到 Twitter Bootstrap拷肌,每個(gè)東西都可以通過按下按鍵(或者敲下命令)來獲取,使用它們吧旨巷!
10. 不要忽略其它語(yǔ)言
如果你是個(gè)
PHP 程序員巨缘,現(xiàn)在有個(gè)好機(jī)會(huì)去至少了解 HTML、CSS契沫、JavaScript 和 MySQL带猴。當(dāng)你能夠更好地處理這些語(yǔ)言時(shí),就是重新學(xué)習(xí)
JavaScript 的時(shí)機(jī)了懈万。JavaScript 并不是 jQuery拴清,你應(yīng)該合理地學(xué)習(xí) JavaScript 來更高效地使用它靶病。
我也打算向你推薦學(xué)習(xí)面向?qū)ο蟮?PHP,它可以節(jié)省時(shí)間口予,并且在代碼規(guī)模更大時(shí)會(huì)變得更好娄周。對(duì)于類似 C# 和 Java 的語(yǔ)言,在你了解 OOP 之后沪停,它們也更易于理解煤辨。
通過了解包管理器、構(gòu)建腳本木张、CoffeeScript众辨、LESS、SASS舷礼、YAML 鹃彻、腳本引擎和其它強(qiáng)大的工具來擴(kuò)展你的知識(shí)面。我強(qiáng)烈向你推薦看一看其它框架妻献,尤其是Laravel蛛株。
當(dāng)你使用它們出色完成任務(wù)時(shí),學(xué)習(xí)
Ruby育拨、RoR谨履、Android、iPhone 和 Windows Phone
應(yīng)用開發(fā)如何熬丧?你可能會(huì)認(rèn)為這毫無(wú)意義笋粟,因?yàn)樗鼈冊(cè)谀愕氖孢m區(qū)和工作所需范圍之外,但是這就是它們的意義锹引。每種語(yǔ)言都有一些要學(xué)習(xí)的實(shí)用的東西矗钟,以及從沒碰到的新知識(shí)。所有
PHP 頂級(jí)開發(fā)者都懂得很多其它編程語(yǔ)言嫌变,這并非偶然吨艇。