php編程規範

来源:http://www.cnblogs.com/china90/archive/2017/08/16/7376520.html
-Advertisement-
Play Games

今天寫這個是為了 提醒自己 編程過程 不僅要有邏輯 思想 還有要規範 代碼 這樣可讀性 感謝我牛神提供的文檔 1、PHP 編程規範與編碼習慣最主要的有以下幾點: 1 文件說明 2 function 函數體說明 3 代碼縮進 4 if省略 5 變數規範 6 命名規範 7 十行一註釋 8 註釋風格 9 ...


今天寫這個是為了 提醒自己 編程過程 不僅要有邏輯 思想 還有要規範 代碼 這樣可讀性 

感謝我牛神提供的文檔

 

1、PHP 編程規範與編碼習慣最主要的有以下幾點:

 1 文件說明

 2 function 函數體說明

 3 代碼縮進

 4 if省略

 5 變數規範

 6 命名規範

 7 十行一註釋

 8 註釋風格

 9 開放關閉原則

2、文件說明 個人代碼 -規範如下:

 1 <?
 2 /*
 3  +----------------------------------------------------------------------
 4  + Title        : 標題
 5  + Author       : 作者
 6  + Version      : 版本號
 7  + Initial-Time : 這個文件初始創建的時間
 8  + Last-time    : 這個文件最後修改的時間 + 修改人的名稱
 9  + Desc         : 這個文件的簡單描述
10  +----------------------------------------------------------------------
11 */

3、Function 函數體說明:

 1 <?
 2 /**
 3  * 函數體簡單的描述
 4  * @author_start : 作者
 5  * @author_end   : 修改時間 + 修改者
 6  * @param string : $id       描述
 7  * @param array  : $array  描述
 8  * @param array  : $num   描述
 9  * @return : 返回值說明
10 */
11 function Test($id, $array = array(), $num = 1){
12 }

註意:Function裡面變數參數的代碼縮進風格

 4、代碼縮進:

 1 <?
 2 $str  = 1;
 3 $info = '123';
 4 $version = '123123';
 5 $name = 'test';
 6 $i    = 'haha';
 7  
 8 # 一般在最外部的if 或流程式控制制語句都應該上下留空一行
 9 if ($info) {
10  
11 }
12  
13 # 一般在最外部的for或者 foreach都應該上下留空一行
14 for ($i=0 ,$i<6 ,$i++){
15  
16 }

5、IF省略

 1 <?
 2 # 一般在if語句與其分支的流程式控制制語句當中,存在這exit或者return的情況下,都應該省略其else的部分操作
 3 # 錯誤
 4 if () {
 5     return false;
 6 } else {
 7     return true;
 8 }
 9 # 正確
10 if () {
11     return false;
12 }
13 return true;

6、變數規範,使用英文命名

1 <?
2 # 正確
3 $title = '標題';
4 $name  = '名稱';
5 $pwd   = '密碼';
6 # 錯誤
7 $biaoti = '標題';
8 $ming   = '名稱';
9 $mima   = '密碼';

7、命名規範

 1 <?
 2 /**
 3  * 實際開發中,命名方式一般有三種情況
 4  * 註意:不管是類名,變數,方法名,在實際開發中,最多只能是不超過3個單詞的組合
 5  * 大駝峰 :每個單詞首字母大寫
 6  * 小駝峰 :中間單詞首字母大寫 
 7  * 蛇形   :每個單詞小寫,單詞與單詞之間使用 _ 符合鏈接
 8  */
 9  
10 # 大駝峰,常用於類名定義
11 class Car{}
12 class BlueCar{}
13  
14 # 小駝峰,常用於方法名定義
15 class Car{
16   public function getColor(){}
17 }
18  
19 # 蛇形,常用於變數名定義
20 $res_id   = 1;
21 $res_name = 2; 

9、註釋風格

 1 <?
 2 1、當需要對某段代碼,做大量描述時,使用以下註釋風格
 3 /**
 4  * 我是說明
 5  * ① 流程一
 6  * ② 流程二
 7  * ③ 流程三
 8  */
 9  
10 2、當需要對一行代碼,做小量描述時,使用以下註釋風格
11 # 這是XXXX給ZZZZ的變數,叫CCCC
12 $name = '';
13  
14 3、當需要對一行代碼,做簡介描述時,使用以下註釋風格
15 $name       = ''; // X表的欄位
16 $index_head = ''; // 首頁請求頭

10、開放關閉原則
     
           實際上這是一個概念,是設計模式中的一種。
           簡單來說,就是一個已經完成上線的class或者api,可以在不改動起原文件的情況下,對其功能進行外部擴展。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • codeplex切換到目前的主流開源中心https://github.com/microsoft 幾個核心技術的站點https://github.com/Microsoft/dotnethttps://github.com/aspnethttps://github.com/microsoft/vsc ...
  • asp.net core微軟官方為日誌提供了原生支持,有如下實現 Console Debug EventLog AzureAppServices TraceSource EventSource 並且在asp.net core項目模板中預設開啟Comsole,Debug的日誌輸出 在實際生產中僅僅是控 ...
  • 摘要:本來說這個企業的門戶網站單純的做做顯示公司文化信息的,做好了老闆說要新增線上辦理業務,本來這個網站是基於別人的框架做的前臺都只能用純html來做。好吧上兩篇我就寫了table裡面向資料庫插入數據《ASP.NET前臺html頁面AJAX提交數據後臺ashx頁面接收數據》跟前臺的查詢數據《ASP.... ...
  • 領域對象:Game(游戲), Room(游戲群),兩者一對多的關係,SQL語句中會用到JOIN 通常用Dapper的Query<TFirst,TSecond,TReturn>() 或 QueryAsync<TFirst,TSecond,TReturn>() 是可以實現,但是去除重覆記錄比較麻煩。 所 ...
  • 一般是訪問https時才出現“508 Loop Detected”,idhttp+IdSSLIOHandlerSocketOpenSSL,這個在上篇文章中講過了。 由於該問題網上資料極少,連外文資料也沒卵用,起初我也以為是idhttp的重定向設置問題,但確認過沒設置錯。 不過相比https,http ...
  • 出現這種問題的原因是由於訪問的 URL地址為https或存在其跳轉地址為https。 首先單純使用idhttp是只能訪問http,而https則需要搭配IdSSLIOHandlerSocketOpenSSL來實現對https的訪問支持,當然還需要在系統目錄或編譯目標程式的同目錄下有ssleay32. ...
  • 安裝好環境後,開始了第一個Hello word 例子,如何讀取圖片,保存圖品 每天學習一點點,睡覺去了。 ...
  • 以前學過點 面向對象的知識,我感覺這之間是有關聯的,比如說裝飾器的第一個要素是對被裝飾的函數的封閉性,不允許更改;第二個就是對裝飾器本oj身的可擴展性。 裝飾器要點:高階函數+嵌套函數=裝飾器 需要掌握的知識點:1、函數即變數 2、高階函數(函數的參數也是函數) 3、嵌套函數 裝飾器一:裝飾器不帶參 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...