91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何優化PHP代碼

發布時間:2021-09-07 10:15:50 來源:億速云 閱讀:152 作者:小新 欄目:web開發

這篇文章主要介紹了如何優化PHP代碼,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

前言

這是一個后臺用戶列表的搜索功能

搜索條件可否并行是否必填
用戶名可以
手機號碼可以
是否已認證可以
用戶性別可以
最近登錄時間可以
賬戶余額可以

初學者代碼

看到這些例子你是否不由的一顫,又要開始造輪子的是不是?

以原生的例子為例,開始你可能會這樣寫(以下為偽代碼) :

if (IS_POST) {      $like = '';      if (isset($_POST['username'])) {          $username = $_POST['username'];          $like .= "username like '%" . $username . "%' and ";      }      if (isset($_POST['phone'])) {          $phone = $_POST['phone'];          $like .= "phone like '%" . $phone . "%' and";      }      if ($_POST['is_auth']) {          $isAuth = $_POST['is_auth'];          $like .= "is_auth like '%" . $isAuth . "%' and";      }      if ($_POST['sex']) {          $sex = $_POST['sex'];          $like .= "sex like '%" . $sex . "%' and";      }      if ($_POST['time']) {          $time = $_POST['time'];          $like .= "time like '%" . $time . "%' and";      }      if ($_POST['wallet']) {          $wallet = $_POST['wallet'];          $like .= "wallet like '%" . $wallet . "%' and";      }      $like = rtrim($like, 'and');      $sql = "SELECT * FROM `user` WHERE {$like}";  } else {      return view('user');  }

封裝

恩...,還不錯,結構清晰,傳統的初學者條型代碼,接下來我們先封裝一下幾塊代碼。

function post($param)  {      return isset($_POST[$param]) ? $_POST[$param] : null;  }  if (IS_POST) {      $like = '';      if (post('username')) {          $username = post('username');          $like .= "username like '%" . $username . "%' and ";      }      if (post('phone')) {          $phone = post('phone');          $like .= "phone like '%" . $phone . "%' and";      }      if (post('is_auth')) {          $isAuth = post('is_auth');          $like .= "is_auth like '%" . $isAuth . "%' and";      }      if (post('sex')) {          $sex = post('sex');          $like .= "sex like '%" . $sex . "%' and";      }      if (post('time')) {          $time = post('time');          $like .= "time like '%" . $time . "%' and";      }      if (post('wallet')) {          $wallet = post('wallet');          $like .= "wallet like '%" . $wallet . "%' and";      }      $like = rtrim($like, 'and');      $sql = "SELECT * FROM `user` WHERE {$like}";  } else {      return view('user');  }

適當使用迭代

恩,至少我們可以自由控制post方法了,但是這類過程化代碼維護性太低,我們再改進下:

function post($param)  {      return isset($_POST[$param]) ? $_POST[$param] : false;  }  function postAll()  {      return $_POST;  }  if (IS_POST) {      $like = '';      foreach (postAll() as $key => $value) {          if (post($key)) {              $like .= "{$key} like '%{$value}%' and";          }      }      $like = rtrim($like, 'and');      $sql = "SELECT * FROM `user` WHERE {$like}";  } else {      return view('user');  }

面向對象

加個迭代代碼看起來還算是整潔了點,作為PHP程序員,寫代碼不面向對象不靠譜,把class加上。

function request($param = null)  {      return new Request($param);  }  class Request  {      public function __construct(string $param = null)      {          return isset($_POST[$param]) ? $_POST[$param] : false;      }      public function all()      {          return $_POST;      }  }  class User  {      public function index()      {          if (IS_POST) {              $like = '';              foreach (request()->all() as $key => $value) {                  if (request($key)) {                      $like .= "{$key} like '%{$value}%' and";                  }              }              $like = rtrim($like, 'and');              $sql = "SELECT * FROM `user` WHERE {$like}";          } else {              return view('user');          }      }  }

對User的改造

我們在對User的類進行改造,做一些判斷及篩選。

function request($param = null)  {      return new Request($param);  }  class Request  {      public function __construct(string $param = null)      {          return isset($_POST[$param]) ? $_POST[$param] : false;      }      public function all()      {          return $_POST;      }  }  class User  {      public $request = [          'username',          'phone',          'is_auth',          'sex',          'time',          'wallet'      ];      public function index()      {          if (IS_POST) {              $like = '';              foreach (request()->all() as $key => $value) {                  if (in_array($key, $this->request) && request($key)) {                      $like .= sprintf("%s like %s and", $key, $value);                  }              }              $like = rtrim($like, 'and');              $sql = "SELECT * FROM `user` WHERE {$like}";         } else {              return view('user');          }      }  }

這就差不多了,對比真是的代碼可能還相差甚遠,我寫這篇文章的目的不是教會你如何寫代碼,是想說明編碼不是一次性的,應經過多次修改,使代碼具有可維護性,擴展性等等的,各種“性”。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何優化PHP代碼”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

聂荣县| 洛川县| 峨眉山市| 石渠县| 大同县| 湛江市| 麻江县| 师宗县| 丽水市| 都安| 五华县| 桦川县| 旬邑县| 东源县| 敖汉旗| 阿巴嘎旗| 潮州市| 城市| 株洲县| 三河市| 灌阳县| 浪卡子县| 湖口县| 兴仁县| 盈江县| 临泽县| 疏勒县| 海伦市| 四子王旗| 修水县| 收藏| 安宁市| 林州市| 资源县| 盘山县| 右玉县| 孟津县| 科技| 许昌市| 靖州| 新巴尔虎左旗|