优化你的PHP代码,从现在做起
前言
我一生的文章都会放在这里,我的博客,我希望每一行代码,每一段文字都能帮助你。https://github.com/CrazyCodes...
大家好,我是CrazyCodes ,今天我们不聊工具、规范等等等等的辅助,就聊一下该如何写一段“好”的代码,本文以我的职业生涯碰到的代码为例,如有出入请在评论区提出异议,谢谢。
搜索功能
搜索很常见,复杂的搜索大多出行在后台,举个栗子,大概需求是这样的
这是一个后台用户列表的搜索功能
搜索条件 | 可否并行 | 是否必填 |
---|---|---|
用户名 | 可以 | 否 |
手机号码 | 可以 | 否 |
是否已认证 | 可以 | 是 |
用户性别 | 可以 | 否 |
最近登录时间 | 可以 | 否 |
账户余额 | 可以 | 否 |
初学者代码
看到这些例子你是否不由的一颤,又要开始造轮子的是不是?
以原生的例子为例,开始你可能会这样写(以下为伪代码)
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');
}
}
}
这就差不多了,对比真是的代码可能还相差甚远,我写这篇文章的目的不是教会你如何写代码,是想说明编码不是一次性的,应经过多次修改,使代码具有可维护性,扩展性等等的,各种“性”
致谢
感谢你看到这里,希望本篇文章可以帮到你,谢谢
Grace development
记录分享开发、学习中的点点滴滴
推荐阅读
海外电商支付网关避坑指南
上一篇我大致描述了支付系统开发的基本流程,但相比之下,国内的流程虽然大同小异,但必要步骤还是完整的,技术水平比较高,但相比之下,对接海外的三方支付就没有我们想象的那么通畅了。
CrazyCodes赞 9阅读 2.6k
怎样用 PHP 来实现枚举?
在数学和计算机科学理论中,一个集的枚举是列出某些有穷序列集的所有成员的程序,或者是一种特定类型对象的计数。这两种类型经常(但不总是)重叠。枚举是一个被命名的整型常数的集合,枚举在日常生活中很常见,...
唯一丶赞 25阅读 6.4k评论 4
PHP转Go实践:xjson解析神器「开源工具集」
我和劲仔都是PHP转Go,身边越来越多做PHP的朋友也逐渐在用Go进行重构,重构过程中,会发现php的json解析操作(系列化与反序列化)是真的香,弱类型语言的各种隐式类型转换,很大程度的减低了程序的复杂度。
王中阳Go赞 10阅读 2k评论 2
图片防盗链破解 解决图片防盗链问题 反向代理
当客户端(浏览器)向服务器请求内容的时候,会提交一个header,这个header中包含了如:浏览器信息、cookie等内容,那么有一个叫referer的东东,也包含在这里面。
TANKING赞 7阅读 11.3k评论 5
Git操作不规范,战友提刀来相见!
年终奖都没了,还要扣我绩效,门都没有,哈哈。这波骚Git操作我也是第一次用,担心闪了腰,所以不仅做了备份,也做了笔记,分享给大家。问题描述小A和我在同时开发一个功能模块,他在优化之前的代码逻辑,我在开...
王中阳Go赞 5阅读 2.3k评论 2
微信公众号开发:自动回复文本/图片/图文消息/关键词回复/上传素材/自定义菜单
对接流程1、申请微信公众号测试账号URL:[链接]2、登录,配置开发者服务器URL和Token开发者服务器配置代码:config.php {代码...} URL是config.php在你服务器的URLToken是上面代码自己设置的Token搞定之后,就能完...
TANKING赞 2阅读 10.1k
2022 年中国开源创新大赛在乌镇正式启动
11 月 10 日上午,在 2022 年世界互联网大会乌镇峰会数字经济分论坛上,2022 中国互联网发展创新与投资大赛暨 2022 年中国开源创新大赛在乌镇正式启动。
MissD赞 2阅读 10.6k
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。