一个好的编码习惯靠平时的习惯养成,团队里有好的编码规范,而且每一个人都按照制定的编码规范来执行,那么我相信代码的质量以及可维护性会上升一个档次。而目前PHP要求都要遵照PSR
标准规范,我只列举一部分编码中经常使用的写法进行说明,更多的规范你们能够搜索PSR标准
。php
对于纯PHP的代码文件,必须以<?php
或者<?
标签开始,而且独占一行,同时不要加?>
的结束标签,至于为啥,感兴趣的本身去了解哈。segmentfault
<?php class TestDemo { }
类名必须以大写开头的驼峰式命名(TestDemo),两个花括号换行且独占一行,同时须要用多行注释说明类的建立人以及做用等。测试
/** * 这是一个测试Demo类 * Author: gxcuizy * Date: 2021-05-25 13:57:16 * Class TestClass */ class TestDemo { }
类中的常量命名必须所有字母都要大写(HELLO_WORLD),同时单词间如下划线_
分隔,并且最好增长注释说明,单行注释最好在//
后先加一个空格再接注释说明。ui
// 声明一个常量 const HELLO_WORLD = 'best';
类中的成员属性(也叫成员变量),成员属性的命名能够遵循三个规则:大写开头的驼峰式($UserName)、小写开头的驼峰式($userName)、下划线分隔式($user_name);这三种命名规则均可以,我我的习惯用下划线分隔式
,你们也能够根据本身的习惯选择,可是最好与团队编码规则保持一致便可,同时三个修饰符(public、protected、private)不能少。编码
// 声明一个公共变量 public $user_name = ''; // 声明一个静态变量 public static $user_age = 18;
类中的成员方法的命名必须采用小写开头的驼峰式命名(testAction)规则,方法的三个修饰符(public、protected、private)不能少,两个花括号换行且独占一行,参数的等号两边各一个空格,方法的注释不要漏了哈,包括方法的做用、参数说明以及返回值说明等。spa
/** * 这是一个测试方法 * @param string $msg 参数说明 * @return array */ public function testAction($msg = '') { // 返回数据格式 $return = array('code' => 200, 'msg' => ''); return $return; } /** * 这是私有方法,方法命名以单下划线开始 * @param string $arg 参数说明 * @return string */ private function privateAction($arg = '') { return $arg; }
相对于运算符或者不一样类型的表达式,无论在任何地方使用,咱们都须要在其符号两边有一个空格,例如$a = 1;
、1 + 2
以及1 && 0
等。调试
/** * 获取两个数相加的和 * @param int $one 第一个数 * @param int $two 第二个数 * @return int */ public function getUserAge($one = 0, $two = 0) { $sum = $one + $two; return $sum; }
相似if …… else
、while
、switch ……case
、foreach
、for
等流程控制结构,基本都须要与括号()
和花括号{}
配合使用,要求括号()
两边均有一个空格,而左花括号{
须要与右括号)
同行且有一个空格,而做为结束的右花括号}
则须要单独一行,而主体内容都是包含在花括号{}
中。代码规范
/** * 判断用户是否成年 * @param int $age 年龄 */ public function logicAction($age = 18) { if ($age >= 18) { echo '已成年'; } else { echo '未成年'; } }
如今不少IDE都支持一键格式化代码,好比PhpStorm
等,通常快捷键都是Ctrl + Alt + L
,你也能够根据你本身的习惯进行修改快捷键以及代码格式的标准,既能够一键格式化整个文档,也能够只选中某一部分代码进行格式化。PS:若是这个文件不是你一我的建立和修改,请不要轻易一键格式化整个文件,由于会把人家的代码也给格式化了,推荐只格式化你本身的代码便可,每一个人都不喜欢别人随意动本身的代码,因此不要搞事情!不要搞事情!不要搞事情!重要的事情说三遍,你懂的。code
先给出我的的几点建议吧,但愿对你有所帮助:orm
我只是抽取了一小部分经常使用到的代码规范说一下,若是有写的不对的地方请你们指出,我会及时修改,谢谢。若是你还有其余好的编码技巧,也欢迎和你们一块儿分享。