首頁 >後端開發 >php教程 >十大你需要在PHP中避免的坑

十大你需要在PHP中避免的坑

烟雨青岚
烟雨青岚轉載
2020-07-15 12:54:082222瀏覽

十大你需要在PHP中避免的坑

1. 不要用 mysql_ 類別函數

終於,你不用再看到建議不要使用 mysql_ 函數的提示了。因為 PHP 7 從核心上完全移除了它們,這意味著請你移步至更好的 mysqli_ 類別函數,或更靈活的 PDO 層。

2. 不要寫無用的程式碼

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

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

作為開發者,應該確保按需載入腳本,可能時再組合,編寫高效的資料庫查詢語句,如果可能的話 使用快取 等等。

3. 不要在檔案結尾使用PHP 閉合標籤

如果你隨便看看,就會發現大部分WordPress 核心程式碼檔案結尾都省略了PHP 閉合標籤。事實上,Zend 框架特別明顯地 禁止了閉合標籤。它並非 PHP 所必須,在檔案結尾處省略它,可確保結尾無額外空白。

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

我個人非常不喜歡引用傳參。我當然知道在某些場合下它很有用,但是多數場合下,它會使得程式碼難以理解,難以遵循,難以預測結果。

人們認為引用可以讓它們的程式碼更快,不過正如 可敬的 PHP 程式設計師 的這篇文章所指出的,事實並非如此。

PHP 內建的 shuffle() 或 sort() 函數,就是一個糟糕的引用傳參案例。它修改了原始數組而不是傳回一個打亂的或排好序的數組,這是完全違背了我們意願的。

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開發人員都了解其他程式語言,這不是偶然的!

感謝大家的閱讀,希望大家收益多多。

本文轉載於:https://www.cnblogs.com/summerblue/p/8778819.html

推薦教學:《php教學

以上是十大你需要在PHP中避免的坑的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除