文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何优化PHP代码

2024-04-02 19:55

关注

这篇文章主要介绍了如何优化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');          }      }  }

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

感谢你能够认真阅读完这篇文章,希望小编分享的“如何优化PHP代码”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯