17611538698
webmaster@21cto.com

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

资讯 0 2284 2019-05-28 11:57:41
本文原载于SegmentFault专栏“Grace Development”
作者:CrazyCodes
整理编辑:SegmentFault
 
今天我们不聊工具、规范等等等等的辅助,就聊一下该如何写一段“好”的代码,本文以作者的职业生涯碰到的代码为例,如有出入请在评论区提出异议,谢谢。
 
搜索功能
 
搜索很常见,复杂的搜索大多出行在后台,举个栗子,大概需求是这样的
这是一个后台用户列表的搜索功能
 

5.28_.4_.1_.png

 
 
初学者代码
 
看到这些例子你是否不由的一颤,又要开始造轮子的是不是?
 
以原生的例子为例,开始你可能会这样写(以下为伪代码)
 
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');}
 
封装
 
恩...,还不错,结构清晰,传统的初学者条型代码,接下来我们先封装一下几块代码。
functionpost($param){ returnisset($_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方法了,但是这类过程化代码维护性太低,我们再改进下
functionpost($param){ returnisset($_POST[$param]) ? $_POST[$param] : false;}functionpostAll(){ 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加上
functionrequest($param = null){ returnnew Request($param);}classRequest{ publicfunction__construct(string $param = null){ returnisset($_POST[$param]) ? $_POST[$param] : false; } publicfunctionall(){ return $_POST; }}classUser{ publicfunctionindex(){ 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的类进行改造,做一些判断及筛选
functionrequest($param = null){ returnnew Request($param);}classRequest{ publicfunction__construct(string $param = null){ returnisset($_POST[$param]) ? $_POST[$param] : false; } publicfunctionall(){ return $_POST; }}classUser{ public $request = [ 'username', 'phone', 'is_auth', 'sex', 'time','wallet' ]; publicfunctionindex(){ 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'); } }}
 
这就差不多了,对比真是的代码可能还相差甚远,我写这篇文章的目的不是教会你如何写代码,是想说明编码不是一次性的,应经过多次修改,使代码具有可维护性,扩展性等等的,各种“性”。

评论