優化你的PHP代碼,從如今作起

clipboard.png

前言

我一輩子的文章都會放在這裏,個人博客,我但願每一行代碼,每一段文字都能幫助你。 https://github.com/CrazyCodes...

你們好,我是CrazyCodes ,今天咱們不聊工具、規範等等等等的輔助,就聊一下該如何寫一段「好」的代碼,本文以個人職業生涯碰到的代碼爲例,若有出入請在評論區提出異議,謝謝。git

搜索功能

搜索很常見,複雜的搜索大多出行在後臺,舉個栗子,大概需求是這樣的程序員

這是一個後臺用戶列表的搜索功能github

搜索條件 能否並行 是否必填
用戶名 能夠
手機號碼 能夠
是否已認證 能夠
用戶性別 能夠
最近登陸時間 能夠
帳戶餘額 能夠

初學者代碼

看到這些例子你是否不禁的一顫,又要開始造輪子的是否是?
以原生的例子爲例,開始你可能會這樣寫(如下爲僞代碼)sql

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方法了,可是這類過程化代碼維護性過低,咱們再改進下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加上this

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');
        }
    }
}

這就差很少了,對比真是的代碼可能還相差甚遠,我寫這篇文章的目的不是教會你如何寫代碼,是想說明編碼不是一次性的,應通過屢次修改,使代碼具備可維護性,擴展性等等的,各類「性」spa

致謝

感謝你看到這裏,但願本篇文章能夠幫到你,謝謝code

相關文章
相關標籤/搜索