PHP 并不需要文件末尾的閉合標(biāo)簽,并且我們可以通過(guò)去掉它來(lái)保證不會(huì)在后面添加任何的空缺字符。很可能不管你需要造出什么,一些人之前早就造出來(lái)了。它給你的系統(tǒng)施加不必要的壓力,并且可能能夠在輪回外部更快獲得相同結(jié)果。
說(shuō)明引用為什么不好的一個(gè)例子是,PHP 內(nèi)建了shuffle()和sort()。
你應(yīng)該明確指定需要哪些行,并且僅僅獲取它們。但這只會(huì)給你和你附近的人產(chǎn)生大麻煩。
1. 不要做不必要的引用傳遞
我個(gè)人不喜歡引用傳遞。
2. 不要信任用戶(hù)輸入
信任用戶(hù)輸入是不明智的。
在 PHP 7 中不要做的 10 件事
3. 不要使用 mysql_ 函數(shù)
這一天終于來(lái)了,從此你不僅僅“不應(yīng)該”使用mysql_函數(shù)。這有助于減少所用資源,保護(hù)數(shù)據(jù),以及讓事情變得盡可能清楚。當(dāng)你能夠更好地處理這些語(yǔ)言時(shí),就是重新學(xué)習(xí) JavaScript 的時(shí)機(jī)了。
4. 不要故作智慧
你的目標(biāo)應(yīng)該是編寫(xiě)優(yōu)雅的代碼,來(lái)更清楚地表達(dá)你的意圖。
5. 不要重新發(fā)明輪子
PHP 到現(xiàn)在為止有很長(zhǎng)時(shí)間了,網(wǎng)站被造出來(lái)的時(shí)間更長(zhǎng)。
公道命名變量,為代碼編寫(xiě)文檔,優(yōu)先選擇清楚而不是簡(jiǎn)潔。當(dāng)我碰到需要這樣的情況時(shí),我通常會(huì)使用兩個(gè)分離的查詢(xún)來(lái)解決題目,我會(huì)使用它們來(lái)構(gòu)建數(shù)據(jù)數(shù)組。
6. 不要在文件末尾使用 PHP 閉合標(biāo)簽
你可以看一看,當(dāng)一個(gè)文件以 PHP 代碼結(jié)尾時(shí),WordPress 多數(shù)核心代碼都把末尾的 PHP 標(biāo)簽去掉了。不管如何,假如可以避免的話(huà),不要在 SQL 查詢(xún)里使用通配符,尤其是數(shù)據(jù)庫(kù)有良多列的時(shí)候。
通過(guò)了解包治理器、構(gòu)建腳本、CoffeeScript、LESS、SASS、YAML 、腳本引擎和其它強(qiáng)盛的工具來(lái)擴(kuò)展你的知識(shí)面。詳見(jiàn)文章校驗(yàn)、轉(zhuǎn)義和過(guò)濾用戶(hù)數(shù)據(jù)。
對(duì)于 SQL,你需要了解所有可用的函數(shù),并且盡可能測(cè)試其速度。用戶(hù)數(shù)據(jù)存在三個(gè)題目:我們開(kāi)發(fā)者并沒(méi)有考慮每種可能性,它通常不準(zhǔn)確,以及它可能是蓄意破壞。
因?yàn)?WordPress 合用于這里,它可能有一些例外。
當(dāng)你使用它們精彩完成任務(wù)時(shí),學(xué)習(xí) Ruby、RoR、Android、iPhone 和 Windows Phone 應(yīng)用開(kāi)發(fā)如何?你可能會(huì)以為這毫無(wú)意義,由于它們?cè)谀愕奶耢o區(qū)和工作所需范圍之外,但是這就是它們的意義。后續(xù)的調(diào)用使用這些緩存數(shù)據(jù),沒(méi)有數(shù)據(jù)庫(kù)的調(diào)用。甚至還可以更好,使用尺度的面向?qū)ο蟠a,它本身或多或少就是文檔,不需要一大堆內(nèi)聯(lián)數(shù)值。固然get_post_meta() 會(huì)從數(shù)據(jù)庫(kù)獲取大量數(shù)據(jù),假如你正在遍歷某個(gè)特殊博文的元數(shù)據(jù)你可以在輪回中使用它。 PHP 7 已經(jīng)把它們從核心中全部移除了,也就是說(shuō)你需要遷移到好得多的mysqli_函數(shù),或者更靈活的 PDO 實(shí)現(xiàn)。對(duì)于類(lèi)似 C# 和 Java 的語(yǔ)言,在你了解 OOP 之后,它們也更易于理解。
7. 不要在 SQL 查詢(xún)中使用 *
當(dāng)然,這個(gè)更像 MySQL 的題目,但是我們習(xí)慣在 PHP 中編寫(xiě) SQL 代碼,所以都差未幾。
據(jù)說(shuō)一些人以為它使代碼運(yùn)行更快,但是根據(jù)一些 PHP 高級(jí)程序員所說(shuō),這并不準(zhǔn)確。
實(shí)際上,Zend 框架特別禁止了它。這是由于當(dāng)你一次調(diào)用它的時(shí)候,WordPress實(shí)際上會(huì)獲取所有元數(shù)據(jù)并緩存它們。之后我會(huì)遍歷數(shù)組,并不需要在這個(gè)過(guò)程中執(zhí)行查詢(xún)。不要害怕向他人尋求支持,Github是你的好朋友,Composer也是,Packagist也是。 JavaScript 并不是 jQuery,你應(yīng)該公道地學(xué)習(xí) JavaScript 來(lái)更高效地使用它。要確保使用類(lèi)似filter_var()的內(nèi)建函數(shù)檢查適當(dāng)?shù)闹担约霸谔幚頂?shù)據(jù)庫(kù)時(shí)轉(zhuǎn)義(或預(yù)編譯)。假如你不確定某個(gè)查詢(xún)的速度,測(cè)試它并且嘗試一些其它的編譯 — 之后使用的那個(gè)。
經(jīng)由周密考慮的系統(tǒng)可以防護(hù)這些威脅。我強(qiáng)烈向你推薦看一看其它框架,尤其是 Laravel。我知道有時(shí)候它很實(shí)用,但是其它情況下它使代碼變得難懂,并且更難猜測(cè)結(jié)果。每種語(yǔ)言都有一些要學(xué)習(xí)的實(shí)用的東西,以及從沒(méi)遇到的新知識(shí)。
為了理解速度有多重要,以及如何把事情做得更好,請(qǐng)看一看我們的文章速度優(yōu)化入門(mén)指南。
WordPress 擁有一些函數(shù)來(lái)解決題目。不要僅僅知足于你的站點(diǎn)速度,由于遷移到 PHP 7 才讓它變快。
8. 不要編寫(xiě)垃圾代碼
這一條可能易于理解,但是會(huì)變得越來(lái)越重要,由于 PHP 7 的速度晉升可能會(huì)躲藏你的一些題目。它們修改原始數(shù)組,而不是返回處理后的數(shù)組,這很分歧邏輯。
我也打算向你推薦學(xué)習(xí)面向?qū)ο蟮?PHP,它可以節(jié)省時(shí)間,并且在代碼規(guī)模更大時(shí)會(huì)變得更好。
弄懂這些的佳方式是閱讀函數(shù)文檔,以及使用類(lèi)似 Query Monitor 的工具。
9. 不要在輪回中執(zhí)行查詢(xún)
在輪回中執(zhí)行查詢(xún)非常鋪張。所有 PHP 開(kāi)發(fā)者都懂得良多其它編程語(yǔ)言,這并非無(wú)意偶然。你可能能夠通過(guò)將任何東西縮短為一個(gè)單詞的變量,使用多層的三元邏輯,以及其它手段,從每個(gè)頁(yè)面中優(yōu)化 0.01 秒。始終校驗(yàn)、過(guò)濾、轉(zhuǎn)義、檢查并留好退路。
作為一名開(kāi)發(fā)者,你應(yīng)該老是確保按需加載腳本,盡可能連接它們,編寫(xiě)高效的數(shù)據(jù)庫(kù)查詢(xún),盡可能使用緩存,以及其它。
從日志工具到調(diào)色工具,從機(jī)能分析器到單元測(cè)試框架,從 Mailchimp API 到 Twitter Bootstrap,每個(gè)東西都可以通過(guò)按下按鍵(或者敲下命令)來(lái)獲取,使用它們吧!
10. 不要忽略其它語(yǔ)言
假如你是個(gè) PHP 程序員,現(xiàn)在有個(gè)好機(jī)會(huì)去至少了解 HTML、CSS、JavaScript 和 MySQL。在計(jì)算均值、乞降或計(jì)算類(lèi)似數(shù)值時(shí),要使用 SQL 函數(shù)而不是 PHP 函數(shù)。