十個你須要在 PHP 7 中避免的坑

clipboard.png

1. 不要使用 mysql_ 類函數

終於,你不用再看到建議不要使用 mysql_ 函數的提示了。由於 PHP 7 從核心上徹底移除了它們,這意味着請你移步至更好的 mysqli_ 類函數,或者更靈活的 PDO 層。php

2. 不要寫無用的代碼

這看上去是個無腦建議,可是隨着 PHP7 速度的提高掩蓋了一些問題使它顯得日趨重要。不要僅僅因切到 PHP7 讓網站速度變得快點,你就沾沾自喜了。html

想理解速度的重要性和如何作的更好,去看看咱們這篇文章 初學者加速優化指南mysql

做爲開發者,應該確保按需加載腳本,可能時再組合,編寫高效的數據庫查詢語句,若是可能的話 使用緩存 等等。laravel

3. 不要在文件末尾使用 PHP 閉合標籤

若是你隨便看看,就會發現大部分 WordPress 核心代碼文件結尾都省略了 PHP 閉合標籤。事實上,Zend 框架尤其明顯地 禁止了閉合標籤。它並不是 PHP 所必須,在文件結尾處省略它,可確保結尾無額外空白。git

4. 如非必須不要引用傳參

我我的很是不喜歡引用傳參。我固然知道在某些場合下它頗有用,可是多數場合下,它會使得代碼難以理解,難以遵循,難以預測結果。程序員

人們認爲引用可使它們的代碼更快,不過正如 可敬的 PHP 程序員 的這篇文章所指出的,事實並不是如此。github

PHP 內置的 shuffle() 或者 sort() 函數,就是糟糕的引用傳參案例。 它修改了原數組而不是返回一個打亂的或者排好序的數組,這是徹底違背了咱們意願的。sql

5. 不要在循環裏使用查詢

在循環中使用數據庫查詢時最糟糕的。他會給系統帶來沒必要要的壓力,而且頗有可能,你能夠在循環外使用查詢而更快的獲得相同的結果。當我碰到必須這樣用的場景時,我一般會經過分紅兩個查詢來構造一個數組的方式來解決。而後循環數組而無需循環查詢。數據庫

因爲 WordPress 的運行方式,這樣作可能會有些例外。 get_post_meta() 將從數據庫獲取一個元數據,若是您正在循環訪問特定文章的元數據,則能夠在循環中使用它。這是由於當你第一次使用它的時候,WordPress 實際上取得了全部的元數據並緩存了起來。 以後的調用其實是調用緩存數據而不是調用數據庫。編程

解決這些問題的最好辦法是閱讀函數文檔而且使用一些相似 查詢監聽器 的東西。

6. 不要在 SQL 查詢中使用 *

好吧,這更像是一個 MySQL 的問題,但咱們更傾向於在代碼中編寫 SQL 語句,因此我說這是個公平的遊戲。無論什麼狀況下,若是你能避免使用通配符,那就不要使用,尤爲是當你的數據庫有不少字段的時候。

明確指定你須要的字段,而且只檢索這些字段。這有助於節省內存,保護數據,而且能讓事情變得更加清晰明白。

在 SQL 方面,儘量的瞭解你可用的函數並測試速度。 當計算平均數,求和以及計算類似的數字的時候,使用 SQL 內置函數而不是 PHP 的函數。 若是你不肯定一個查詢的速度快慢,測試一下它並和其餘作法進行比較,選出最好的那一種。

7. 不要信任用戶的輸入

信任用戶輸入並不明智。對於用戶輸入,老是須要過濾,殺毒,轉義,校驗以及使用回退。 用戶輸入存在三個問題:咱們開發者不可能考慮到全部可能性,常常出錯,存心的惡意輸入。

一個通過深思熟慮的系統能夠防止全部的這些問題。 在使用數據庫時,確保使用內置的函數,如 filter_var(),來檢查合法性,進行轉義,和其餘能作的事。

WordPress 有一堆函數能夠幫到你。能夠瞧一瞧這篇文章來了解更多信息 Validating, escaping and sanitising user data 。

8. 不要自做聰明

你的目標就是寫出能清晰的表達你的意願的優雅代碼。可能你經過縮短變量名,使用多層級三目邏輯運算和其餘小聰明讓每一個頁面節約了0.01秒的加載時間,可是和所以種下你和你的團隊頭疼不已難以維護的惡果相比,得不償失。

恰當的命名變量,以簡潔明瞭的方式寫出代碼文檔。更好的作法就是,使用標準化的面向對象的代碼風格,或多或少的編寫文檔,而非使用大量的內聯代碼註釋。

9. 不要重複造輪子

PHP 已經存在有一段時間了,網站開發存在的時間甚至更久遠。 不管你作過啥,前人確定已經作過。不要懼怕依賴別人的支持, Github, Composer , Packagist 都是你的良師益友。

從日誌到顏色處理器,從分析器到單元測試框架,從 Mailchimp APIs 到 Twitter Bootstrap,全部的東西只須要按一個按鈕(或者敲一個命令)就能用,去使用它們吧!

10. 不要忽視其餘語言

若是你是個 PHPer,如今的標準作法是至少了解 HTML,CSS,Javascript 和 MySQL。 當你能很好的處理這些語言的時候,就是再去學習一遍 Javascript 的時候。Javascript 不是 jQuery。你應該學習 Javascript 來有效的利用 jQuery。

我也建議學習 PHP 面向對象的一切。它是個救星,能讓你的代碼在數量級上獲得提高。它也能打開相似 C# 和 Java 語言的大門,在你有了這些經驗後,它們能讓你更容易明白麪向對象編程(OOP)。

經過學習包管理,構建腳本,Coffeescript, LESS, SASS, YAML, 模板引擎以及其餘有用的工具來擴展知識面。我也由衷的推薦看看其餘框架,尤爲是 Laravel 。

當你這些都作得夠好了的時候,考慮下 Ruby, Ruby on Rails 以及 Android,iPhone,Windows Phone 的 app 開發? 你可能認爲這些毫無心義,由於它們不在你的溫馨區和工做需求以內,但它們偏偏是重點。 每種語言都有一些有用的教學知識和一些無害的額外知識。全部頂尖的PHP開發人員都瞭解其餘編程語言,這不是偶然的!

更多現代化 PHP 知識,請前往 Laravel / PHP 知識社區
相關文章
相關標籤/搜索