内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

如何優(yōu)化PHP代碼

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

創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)公司,提供網(wǎng)站建設(shè)、成都做網(wǎng)站,網(wǎng)頁(yè)設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);可快速的進(jìn)行網(wǎng)站開發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,是專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!

前言

這是一個(gè)后臺(tái)用戶列表的搜索功能

搜索條件可否并行是否必填
用戶名可以
手機(jī)號(hào)碼可以
是否已認(rèn)證可以
用戶性別可以
最近登錄時(shí)間可以
賬戶余額可以

初學(xué)者代碼

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

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

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');  }

封裝

恩...,還不錯(cuò),結(jié)構(gòu)清晰,傳統(tǒng)的初學(xué)者條型代碼,接下來我們先封裝一下幾塊代碼。

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');  }

適當(dāng)使用迭代

恩,至少我們可以自由控制post方法了,但是這類過程化代碼維護(hù)性太低,我們?cè)俑倪M(jìn)下:

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');  }

面向?qū)ο?/strong>

加個(gè)迭代代碼看起來還算是整潔了點(diǎn),作為PHP程序員,寫代碼不面向?qū)ο蟛豢孔V,把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');          }      }  }

對(duì)User的改造

我們?cè)趯?duì)User的類進(jìn)行改造,做一些判斷及篩選。

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');          }      }  }

這就差不多了,對(duì)比真是的代碼可能還相差甚遠(yuǎn),我寫這篇文章的目的不是教會(huì)你如何寫代碼,是想說明編碼不是一次性的,應(yīng)經(jīng)過多次修改,使代碼具有可維護(hù)性,擴(kuò)展性等等的,各種“性”。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何優(yōu)化PHP代碼”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

本文名稱:如何優(yōu)化PHP代碼
文章分享:http://m.rwnh.cn/article12/jcjdgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站網(wǎng)站改版、標(biāo)簽優(yōu)化用戶體驗(yàn)、網(wǎng)頁(yè)設(shè)計(jì)公司搜索引擎優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

城步| 临夏市| 吴川市| 永胜县| 武胜县| 苏尼特左旗| 洪泽县| 乐昌市| 开阳县| 奉化市| 伊吾县| 德昌县| 张家界市| 左权县| 万年县| 江门市| 合山市| 奇台县| 韩城市| 收藏| 精河县| 洱源县| 东港市| 桂平市| 长白| 英德市| 苏尼特左旗| 博爱县| 新邵县| 枣强县| 陆良县| 临西县| 绥江县| 札达县| 龙井市| 新乡市| 南乐县| 九台市| 屏边| 聊城市| 遵化市|