优化你的PHP代码,从现在做起

前言

按需设计网站可以根据自己的需求进行定制,成都网站建设、成都网站制作构思过程中功能建设理应排到主要部位公司成都网站建设、成都网站制作的运用实际效果公司网站制作网站建立与制做的实际意义

我一生的文章都会放在这里,我的博客,我希望每一行代码,每一段文字都能帮助你。https://github.com/CrazyCodes...

大家好,我是CrazyCodes ,今天我们不聊工具、规范等等等等的辅助,就聊一下该如何写一段“好”的代码,本文以我的职业生涯碰到的代码为例,如有出入请在评论区提出异议,谢谢。

搜索功能

搜索很常见,复杂的搜索大多出行在后台,举个栗子,大概需求是这样的。

这是一个后台用户列表的搜索功能

搜索条件 可否并行 是否必填
用户名 可以
手机号码 可以
是否已认证 可以
用户性别 可以
最近登录时间 可以
账户余额 可以

初学者代码

看到这些例子你是否不由的一颤,又要开始造轮子的是不是?

以原生的例子为例,开始你可能会这样写(以下为伪代码) :

 
 
 
  1. if (IS_POST) { 
  2.     $like = ''; 
  3.     if (isset($_POST['username'])) { 
  4.         $username = $_POST['username']; 
  5.         $like .= "username like '%" . $username . "%' and "; 
  6.     } 
  7.     if (isset($_POST['phone'])) { 
  8.         $phone = $_POST['phone']; 
  9.         $like .= "phone like '%" . $phone . "%' and"; 
  10.     } 
  11.     if ($_POST['is_auth']) { 
  12.         $isAuth = $_POST['is_auth']; 
  13.         $like .= "is_auth like '%" . $isAuth . "%' and"; 
  14.     } 
  15.     if ($_POST['sex']) { 
  16.         $sex = $_POST['sex']; 
  17.         $like .= "sex like '%" . $sex . "%' and"; 
  18.     } 
  19.     if ($_POST['time']) { 
  20.         $time = $_POST['time']; 
  21.         $like .= "time like '%" . $time . "%' and"; 
  22.     } 
  23.     if ($_POST['wallet']) { 
  24.         $wallet = $_POST['wallet']; 
  25.         $like .= "wallet like '%" . $wallet . "%' and"; 
  26.     } 
  27.     $like = rtrim($like, 'and'); 
  28.     $sql = "SELECT * FROM `user` WHERE {$like}"; 
  29. } else { 
  30.     return view('user'); 

封装

恩...,还不错,结构清晰,传统的初学者条型代码,接下来我们先封装一下几块代码。

 
 
 
  1. function post($param) 
  2.     return isset($_POST[$param]) ? $_POST[$param] : null; 
  3. if (IS_POST) { 
  4.     $like = ''; 
  5.     if (post('username')) { 
  6.         $username = post('username'); 
  7.         $like .= "username like '%" . $username . "%' and "; 
  8.     } 
  9.     if (post('phone')) { 
  10.         $phone = post('phone'); 
  11.         $like .= "phone like '%" . $phone . "%' and"; 
  12.     } 
  13.     if (post('is_auth')) { 
  14.         $isAuth = post('is_auth'); 
  15.         $like .= "is_auth like '%" . $isAuth . "%' and"; 
  16.     } 
  17.     if (post('sex')) { 
  18.         $sex = post('sex'); 
  19.         $like .= "sex like '%" . $sex . "%' and"; 
  20.     } 
  21.     if (post('time')) { 
  22.         $time = post('time'); 
  23.         $like .= "time like '%" . $time . "%' and"; 
  24.     } 
  25.     if (post('wallet')) { 
  26.         $wallet = post('wallet'); 
  27.         $like .= "wallet like '%" . $wallet . "%' and"; 
  28.     } 
  29.     $like = rtrim($like, 'and'); 
  30.     $sql = "SELECT * FROM `user` WHERE {$like}"; 
  31. } else { 
  32.     return view('user'); 

适当使用迭代

恩,至少我们可以自由控制post方法了,但是这类过程化代码维护性太低,我们再改进下:

 
 
 
  1. function post($param) 
  2.     return isset($_POST[$param]) ? $_POST[$param] : false; 
  3. function postAll() 
  4.     return $_POST; 
  5. if (IS_POST) { 
  6.     $like = ''; 
  7.     foreach (postAll() as $key => $value) { 
  8.         if (post($key)) { 
  9.             $like .= "{$key} like '%{$value}%' and"; 
  10.         } 
  11.     } 
  12.     $like = rtrim($like, 'and'); 
  13.     $sql = "SELECT * FROM `user` WHERE {$like}"; 
  14. } else { 
  15.     return view('user'); 

面向对象

加个迭代代码看起来还算是整洁了点,作为PHP程序员,写代码不面向对象不靠谱,把class加上。

 
 
 
  1. function request($param = null) 
  2.     return new Request($param); 
  3. class Request 
  4.     public function __construct(string $param = null)
  5.     { 
  6.         return isset($_POST[$param]) ? $_POST[$param] : false; 
  7.     } 
  8.     public function all() 
  9.     { 
  10.         return $_POST; 
  11.     } 
  12. class User 
  13.     public function index() 
  14.     { 
  15.         if (IS_POST) { 
  16.             $like = ''; 
  17.             foreach (request()->all() as $key => $value) { 
  18.                 if (request($key)) { 
  19.                     $like .= "{$key} like '%{$value}%' and"; 
  20.                 } 
  21.             } 
  22.             $like = rtrim($like, 'and'); 
  23.             $sql = "SELECT * FROM `user` WHERE {$like}"; 
  24.         } else { 
  25.             return view('user'); 
  26.         } 
  27.     } 

对User的改造

我们在对User的类进行改造,做一些判断及筛选。

 
 
 
  1. function request($param = null) 
  2.     return new Request($param); 
  3. class Request 
  4.     public function __construct(string $param = null) 
  5.     { 
  6.         return isset($_POST[$param]) ? $_POST[$param] : false; 
  7.     } 
  8.     public function all() 
  9.     { 
  10.         return $_POST; 
  11.     } 
  12. class User 
  13.     public $request = [ 
  14.         'username', 
  15.         'phone', 
  16.         'is_auth', 
  17.         'sex', 
  18.         'time', 
  19.         'wallet' 
  20.     ]; 
  21.     public function index() 
  22.     { 
  23.         if (IS_POST) { 
  24.             $like = ''; 
  25.             foreach (request()->all() as $key => $value) { 
  26.                 if (in_array($key, $this->request) && request($key)) { 
  27.                     $like .= sprintf("%s like %s and", $key, $value); 
  28.                 } 
  29.             } 
  30.             $like = rtrim($like, 'and'); 
  31.             $sql = "SELECT * FROM `user` WHERE {$like}";
  32.         } else { 
  33.             return view('user'); 
  34.         } 
  35.     } 
  36. }

这就差不多了,对比真是的代码可能还相差甚远,我写这篇文章的目的不是教会你如何写代码,是想说明编码不是一次性的,应经过多次修改,使代码具有可维护性,扩展性等等的,各种“性”。

分享名称:优化你的PHP代码,从现在做起
转载注明:http://www.shufengxianlan.com/qtweb/news37/90287.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联