新聞中心
前言

按需設(shè)計(jì)網(wǎng)站可以根據(jù)自己的需求進(jìn)行定制,成都網(wǎng)站建設(shè)、成都網(wǎng)站制作構(gòu)思過(guò)程中功能建設(shè)理應(yīng)排到主要部位公司成都網(wǎng)站建設(shè)、成都網(wǎng)站制作的運(yùn)用實(shí)際效果公司網(wǎng)站制作網(wǎng)站建立與制做的實(shí)際意義
我一生的文章都會(huì)放在這里,我的博客,我希望每一行代碼,每一段文字都能幫助你。https://github.com/CrazyCodes...
大家好,我是CrazyCodes ,今天我們不聊工具、規(guī)范等等等等的輔助,就聊一下該如何寫(xiě)一段“好”的代碼,本文以我的職業(yè)生涯碰到的代碼為例,如有出入請(qǐng)?jiān)谠u(píng)論區(qū)提出異議,謝謝。
搜索功能
搜索很常見(jiàn),復(fù)雜的搜索大多出行在后臺(tái),舉個(gè)栗子,大概需求是這樣的。
這是一個(gè)后臺(tái)用戶(hù)列表的搜索功能
| 搜索條件 | 可否并行 | 是否必填 |
|---|---|---|
| 用戶(hù)名 | 可以 | 否 |
| 手機(jī)號(hào)碼 | 可以 | 否 |
| 是否已認(rèn)證 | 可以 | 是 |
| 用戶(hù)性別 | 可以 | 否 |
| 最近登錄時(shí)間 | 可以 | 否 |
| 賬戶(hù)余額 | 可以 | 否 |
初學(xué)者代碼
看到這些例子你是否不由的一顫,又要開(kāi)始造輪子的是不是?
以原生的例子為例,開(kāi)始你可能會(huì)這樣寫(xiě)(以下為偽代碼) :
- 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');
- }
封裝
恩...,還不錯(cuò),結(jié)構(gòu)清晰,傳統(tǒng)的初學(xué)者條型代碼,接下來(lái)我們先封裝一下幾塊代碼。
- 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');
- }
適當(dāng)使用迭代
恩,至少我們可以自由控制post方法了,但是這類(lèi)過(guò)程化代碼維護(hù)性太低,我們?cè)俑倪M(jìn)下:
- 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');
- }
面向?qū)ο?/strong>
加個(gè)迭代代碼看起來(lái)還算是整潔了點(diǎn),作為PHP程序員,寫(xiě)代碼不面向?qū)ο蟛豢孔V,把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');
- }
- }
- }
對(duì)User的改造
我們?cè)趯?duì)User的類(lèi)進(jìn)行改造,做一些判斷及篩選。
- 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');
- }
- }
- }
這就差不多了,對(duì)比真是的代碼可能還相差甚遠(yuǎn),我寫(xiě)這篇文章的目的不是教會(huì)你如何寫(xiě)代碼,是想說(shuō)明編碼不是一次性的,應(yīng)經(jīng)過(guò)多次修改,使代碼具有可維護(hù)性,擴(kuò)展性等等的,各種“性”。
本文題目:優(yōu)化你的PHP代碼,從現(xiàn)在做起
轉(zhuǎn)載源于:http://www.dlmjj.cn/article/cdsossg.html


咨詢(xún)
建站咨詢(xún)
