前言

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

搜索功能

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

工作十二年准备的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');        }    }}

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

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要的可以点击此处查看详细资料

喜欢我的文章就关注我吧,持续更新中.....

php time相差12小时_优化你的PHP代码,从现在做起相关推荐

  1. MySQL插入数据与系统时间相差12小时

    MySQL插入数据与系统时间相差12小时 serverTimezone改成Asia/Shanghai和GMT%2B8都不行 怎么解决!!

  2. centos服务器 java 项目new Date()相差12小时

    环境:centos 7.x 项目语言:java 项目中使用 new Date()方法发现取值时间与当前时间相差12个小时左右,第一反应是服务器的时间不正确.在服务器调用命令 date [root@lo ...

  3. php time相差12小时_PHP获取时间比实际时间少8小时的问题

    有两方法 1.我们写PHP程序在获取时间时,人为加上8小时(这种方法是最实用也是最土的方法) 2.如果直接获取正确时间,也可修改PHP的配置文件,即查找php.ini文件 修改方法:在php.ini文 ...

  4. serv-u 用户时间显示相差8小时_调好闹钟!4月8日凌晨,将迎来今年最大满月

    天文预报显示,4月8日凌晨,今年第二次"超级月亮"将现身夜空,这是人们今年最佳的一次赏月良机. 据介绍,4月8日的"超级月亮"是继3月10日之后,今年的第二次& ...

  5. MySQL数据库时间和jdbc查询时间相差12小时问题解决

    问题: 数据库所在操作系统时间正常(date命令),使用"select now() from dual;"在数据库管理工具查询,显示时间亦正常(与当前时间一致),但是通过jdbc查 ...

  6. php 获取当前时间相差12小时_php时间戳转换差8小时问题

    PHP时间大的来分有两种,一是时间戳类型(1228348800),二是正常日期格式(2008-12-4) 所以存到数据库也有两种形式了(真正不止,我的应用就两种),时间戳类型我是保存为字符串的,这个是 ...

  7. php time相差12小时_PHP服务器时间差8小时解决方案

    来源:http://my.oschina.net/jackguo/blog/126721 ---------------------------------- date('Y-m-d H:i:s') ...

  8. mongodb时间范围查询少8个小时_为何要对开源mongodb数据库内核做二次开发

    关于作者 前滴滴出行技术专家,现任OPPO文档数据库mongodb负责人,负责oppo千万级峰值TPS/十万亿级数据量文档数据库mongodb内核研发及运维工作,一直专注于分布式缓存.高性能服务端.数 ...

  9. 1小时赚300块,不打代码帮人做个吃鸡网页 [IVX实战第3篇]

    作者简介 作者名:1_bit 简介:CSDN博客专家,2020年博客之星TOP5,蓝桥签约作者.15-16年曾在网上直播,带领一批程序小白走上程序员之路.欢迎各位小白加我咨询我相关信息,迷茫的你会找到 ...

最新文章

  1. 细化 Sobel 边缘提取
  2. linux 占用缓存前10_Linux 中的零拷贝技术
  3. 汇编环境搭建(vs2010(2012)+masm32)
  4. spring8: di依赖注入--构造注入
  5. 0119吧 iPhone 屏幕尺寸
  6. python如何安装scrapy_Python爬虫之Scrapy的安装
  7. 关于python的if条件语句,whilefor循环等的简单说。
  8. CCNA-第八篇-OSPF-上
  9. Linux进程全解5——父子进程对文件的操作
  10. LeetCode 576. 出界的路径数(动态规划)
  11. 检查各计算机所属工作组ip,如何在Win8.1/RT 8.1中添加语言或键盘
  12. 如何在Redhat 7 Linux系统上停止/启动和禁用/启用防火墙
  13. 单应性矩阵的相关理解
  14. DrawIndexedPrimitiveUP这个函数
  15. 淘宝/天猫/京东/抖音直播年货节抢购秒杀助手更新下载,喵惠抢购助手支持自动免密支付,分享源码共同学习探讨
  16. mysql or 索引失效_MySQL索引失效的几种情况详析
  17. LimeSDR-USB硬件部分详细解读
  18. 智能电视硬件架构设计——整机研发
  19. Android图像处理之GPUImage for Android
  20. 2018年android常用的框架介绍

热门文章

  1. python分类器鸢尾花怎么写_python机器学习基础教程-鸢尾花分类
  2. 江南大学人工智能与计算机学院拟录取名单,江南大学人工智能与计算机学院关于接收2021级硕士研究生调剂的通知...
  3. MySQL · 最佳实践 · 什么时候该升级内存规格
  4. tar从压缩包里解压出指定文件
  5. IDEA下用freemarker热更新的问题
  6. 【转】无法将notepad++添加到打开方式列表中的解决办法
  7. 使用autoconf完成编译配置
  8. Keypress - 捕获键盘输入的JavaScript库
  9. go package学习——os
  10. 新僵尸病毒猖獗 Facebook成攻击目标