php编程风格规范,PHP 编码风格规范指南
概览
代码必需遵循 “基础编码标准” PSR [PSR-1]。
代码缩进必须使用 4 空格,而不是tab。
行长度必须无硬性限制; 软性限制必须为120字符;应该少于等于80字。
namespace声明后必须有一个空行,use声明后也必须有一个空行。
类的{ 必须在类名的下一行, }必须在body的下一行。
方法的 { 必须在方法签名的下一行,} 必须在body的下一行。
所有的属性和方法都要设置可见性; abstract和 final必须在可见性之前声明;static 必须在可见性后声明。
结构控制关键词后必须有一个空格; 方法和函数必须没有空格。
结构控制的 { 必须在同一行,} 必须在body的下一行。
结构控制的 ( 后必须有空格, 结构控制的 ) 前必须没有空格。
例子
下面是一个综合的例子,可以帮助你对规则有一个概略的认识。
namespace Vendor\Package;
use FooInterface;
use BarClass as Bar;
use OtherVendor\OtherPackage\BazClass;
class Foo extends Bar implements FooInterface
{
public function sampleFunction($a, $b = null)
{
if ($a === $b) {
bar();
} elseif ($a > $b) {
$foo->bar($arg1);
} else {
BazClass::bar($arg2, $arg3);
}
}
final public static function bar()
{
// 方法 body
}
}
基本规则
基本编码标准
代码必须遵循PSR-1的条款。
文件
所有文件必须使用 Unix LF (linefeed) 换行。
所有PHP文件必须使用单个空行结束。
只包含PHP的代码必须忽略php结束标记 ? >。
行
行长度必须没有硬性限制。
长度的软性限制必须为120字符;自动代码风格检查必须将120字设置为警告,必须不能设置为错误。
行不应该超过80字符;超过这个长度的行应该切分为多个不超过80字符的行。
非空行的结束必须没有尾随空格。
为增强可读性,可增加空行来标志代码的关联性。
每行包含的语句必须不能超过1条。
缩进
代码必须使用 4 空格的缩进, 必须不用tab作为缩进。
注意:只使用空格,不用tab,有助于避免diffs,patches, history和annotations的问题。使用空格也有助于对齐。
关键词(保留字) 和 true/false/null
PHP保留字必须小写.
PHP常量 true, false和 null 必须小写.
Namespace 和 Use 声明
namespace 声明之后必须有空行。
所有use 声明,必须在namespace声明之后。
每个声明必须单独使用一个use。
use声明区之后必须有一个空行。
例如:
namespace Vendor\Package;
use FooClass;
use BarClass as Bar;
use OtherVendor\OtherPackage\BazClass;
// ... additional PHP code ...
类, 属性 和 方法
这里的“类”包括 class、interface 和 trait。
继承 和 实现
extends 和 implements 关键字必须和类名在同一行声明。
类的 { 必须独占一行; } 必须在body的下一行。
namespace Vendor\Package;
use FooClass;
use BarClass as Bar;
use OtherVendor\OtherPackage\BazClass;
class ClassName extends ParentClass implements \ArrayAccess, \Countable
{
// constants, properties, methods
}
implements 多个接口时,接口列表可以被分到多行,每个子行有一个缩进。如果这么做,第一个接口必须在implements 下一行,每行只能有一个接口。
namespace Vendor\Package;
use FooClass;
use BarClass as Bar;
use OtherVendor\OtherPackage\BazClass;
class ClassName extends ParentClass implements
\ArrayAccess,
\Countable,
\Serializable
{
// constants, properties, methods
}
属性
所有属性都必须声明 visibility(可见性)。
Var 关键字必须不能用于声明属性。
每行必须只声明一个属性。
不应该通过前缀下划线来标示protected和private的属性。
例:
namespace Vendor\Package;
class ClassName
{
public $foo = null;
}
方法
所有方法都必须声明可见性。
不应该通过前缀下划线来标示protected和private的方法。
声明方法时,方法名的后必须没有空格。 { 必须在同一行, } 必须在body的下一行。 (后必须没有空格,) 前必须没有空格。
一个方法声明的例子如下,注意 小括号,逗号,空格 和 花括号 的位置:
namespace Vendor\Package;
class ClassName
{
public function fooBarBaz($arg1, &$arg2, $arg3 = [])
{
// method body
}
}
方法参数
方法的形参列表中, 每个逗号前必须没有空格。有默认值的参数必须在参数列表的最后。
namespace Vendor\Package;
class ClassName
{
public function foo($arg1, &$arg2, $arg3 = [])
{
// method body
}
}
参数列表可以切分为多行,每个子行要有一个缩进。如果这么做,第一个参数必须独占一行,每行只能有一个参数。
参数列表切分为多行时,右括号)和左花括号{必须在同一行,之前必须有一个空格。
namespace Vendor\Package;
class ClassName
{
public function aVeryLongMethodName(
ClassTypeHint $arg1,
&$arg2,
array $arg3 = []
) {
// method body
}
}
abstract, final 和 static
abstract和final声明必须在可见性之前声明。
static声明必须在可见性之后。
namespace Vendor\Package;
abstract class ClassName
{
protected static $foo;
abstract protected function zim();
final public static function bar()
{
// method body
}
}
方法和函数调用
写方法或函数调用时,方法/函数名 和 左括号( 之间,必须没有空格, 右括号 ) 之前必须没有空格。在参数列表中,逗号间必须没有逗号,每个逗号后必须有一个空格。
$foo->bar(
$longArgument,
$longerArgument,
$muchLongerArgument
);
控制结构
控制结构通常遵循以下风格:
控制结构关键词后必须有一个空格。
左括号后必须没有空格。
右括号前必须没有空格。
又括号和左花括号之间必须有一个空格。
body必须有一层缩进。
右花括号必须在body下一行。
每个控制结构的body必须用花括号括起来。 即保证外观统一,又减少了添加新行时引入的错误。
if, elseif, else
if 结构如下所示。注意括号、空格、花括号的位置;同时留意 else 和 elseif 与前一部分的 } 在同一行。
if ($expr1) {
// if body
} elseif ($expr2) {
// elseif body
} else {
// else body;
}
elseif关键字不应该被 else if 代替。
switch, case
Switch结构如下所示。注意括号、空格和花括号的位置。 case 语句相对于switch必须有一个缩进, break关键字 或者其他终结性的关键字必须和case body在同一缩进层级。在非空的case body,如果没有终结性语句,必须加上注释 // no break。
switch ($expr) {
case 0:
echo 'First case, with a break';
break;
case 1:
echo 'Second case, which falls through';
// no break
case 2:
case 3:
case 4:
echo 'Third case, return instead of break';
return;
default:
echo 'Default case';
break;
}
while, do while
while结构如下所示。 注意括号、空格和花括号的位置。
while ($expr) {
// structure body
}
do-while接口如下所示。 注意括号、空格和花括号的位置。
do {
// structure body;
} while ($expr);
for
for 结构如下所示。 注意括号、空格和花括号的位置。
for ($i = 0; $i < 10; $i++) {
// for body
}
foreach
foreach 结构如下所示。 注意括号、空格和花括号的位置。
foreach ($iterable as $key => $value) {
// foreach body
}
try, catch
try-catch区块如下所示。 注意括号、空格和花括号的位置。
try {
// try body
} catch (FirstExceptionType $e) {
// catch body
} catch (OtherExceptionType $e) {
// catch body
}
Closure 闭包
声明闭包必须在function关键字后留一个空格,在use关键字前后各留一个空格。
左花括号必须在同一行, 右花括号必须在body的下一行。
参数或变量列表的左括号后 和 右括号前必须没有空格。
参数和变量列表的逗号前必须没有空格,每个逗号后必须有一个空格。
有默认值的参数必须排在最后。
闭包的声明如下所示。 注意括号,逗号,空格和花括号的位置:
$closureWithArgs = function ($arg1, $arg2) {
// body
};
$closureWithArgsAndVars = function ($arg1, $arg2) use ($var1, $var2) {
// body
};
参数列表和变量列表可以拆分到多行,每个子行有一层缩进。 这么做的时候,第一个列表成员必须独占一行,每行只能有一个列表成员。
参数或变量列表拆分为多行时,到了列表的末尾, 右括号 和 左花括号必须放在同一行,中间有一个空格。
例子:
$longArgs_noVars = function (
$longArgument,
$longerArgument,
$muchLongerArgument
) {
// body
};
$noArgs_longVars = function () use (
$longVar1,
$longerVar2,
$muchLongerVar3
) {
// body
};
$longArgs_longVars = function (
$longArgument,
$longerArgument,
$muchLongerArgument
) use (
$longVar1,
$longerVar2,
$muchLongerVar3
) {
// body
};
$longArgs_shortVars = function (
$longArgument,
$longerArgument,
$muchLongerArgument
) use ($var1) {
// body
};
$shortArgs_longVars = function ($arg) use (
$longVar1,
$longerVar2,
$muchLongerVar3
) {
// body
};
注意:当闭包被直接作为函数或方法调用的参数时,以上规则同样适用。
$foo->bar(
$arg1,
function ($arg2) use ($var1) {
// body
},
$arg3
);
结语
本指南刻意忽略了许多风格和实践。包括但不限于:
声明全局变量和全局常量。
声明函数。
操作符和赋值。
行间对齐。
注释和文档区。
类名前后缀。
最佳实践。
php编程风格规范,PHP 编码风格规范指南相关推荐
- php psr 编码规范_PHP编码风格规范
由于PHP的灵活性,很多人写起代码来也不讲求一个好的代码规范,使得本就灵活的PHP代码看起来很乱,其实PSR规范中的PSR-1和PSR-2已经定义了在PHP编码中的一些规范,只要我们好好遵守这些规范, ...
- js编码书写规范(自学习用)
本人平时在书写代码的过程中比较随意,为了能够更优雅的书写代码,整理下列规则 1 编码风格 1.1 缩进 1.1.1[强制]使用 2 个空格缩进. 统一使用 2 个空格缩进,不要使用 4 个空格或 ta ...
- 阿里php开发规范,【PHP开发规范】老生常谈的PSR开发规范你懂多少?
这几天看了一下阿里技术发布的一套Java开发规范<阿里巴巴Java开发手册>,里面写了阿里内部的Java开发规范标准,写的很好.这套Java统一规范标准将有助于提高行业编码规范化水平,帮助 ...
- Python编码规范和Python风格规范
一.原因 1.长期的工作中,发现大多数程序员的代码可读性差 2.不同的程序员之间的协作很重要,代码可读性必须很好 3.版本升级时,要基于源码升级 4.不友好的代码会影响python的执行效率 二.基于 ...
- 「PSR 规范」PSR-2 编码风格规范
所有 PSR 规范请见:https://learnku.com/docs/psr https://learnku.com/laravel/t/2079/psr-specification-psr-2- ...
- 【PHP开发规范】继承与扩展:PSR-2 编码风格规范
之前的一篇文章是对PSR-1的基本介绍 接下来是PSR-2 编码风格规范,它是 PSR-1 基本代码规范的继承与扩展. PSR-1 和PSR-2是PHP开发中基本的编码规范,大家其实都可以参考学习下, ...
- php psr-2,「PSR 规范」PSR-2 编码风格规范
编码风格指南 本篇规范是 PSR-1 基本代码规范的继承与扩展. 本规范希望通过制定一系列规范化PHP代码的规则,以减少在浏览不同作者的代码时,因代码风格的不同而造成不便. 当多名程序员在多个项目中合 ...
- php 结构体_【开发规范】PHP编码开发规范下篇:PSR-2编码风格规范
之前的一篇文章是对PSR-1的基本介绍 接下来是PSR-2 编码风格规范,它是 PSR-1 基本代码规范的继承与扩展. PSR-1 和PSR-2是PHP开发中基本的编码规范,大家其实都可以参考学习下, ...
- PHP编码规范 代码样式风格规范
一.基本约定 1.源文件 (1).纯PHP代码源文件只使用 <?php 标签,省略关闭标签 ?> : (2).源文件中PHP代码的编码格式必须是无BOM的UTF-8格式: (3).使用 U ...
- php团队规范,PHP团队 编码规范 代码样式风格规范
一.基本约定 1.源文件 2.缩进 3.行 4.关键字 和 True/False/Null 5.命名 6.代码注释标签 7.业务模块 二.代码样式风格 1.命名空间(Namespace) 和 导入(U ...
最新文章
- 大学生计算机实验基础考试,大学生计算机基础考试试题
- mybatis多排序问题
- java 所有子类_java 查找类的所有子类
- 玩ts要注意什么_番禺三维创意拍摄要注意什么
- java共享租车信息管理系统jsp源码
- MapReduce案例
- Ubuntu中DenyHosts清除黑名单IP地址
- java过去localhost出错,http://localhost:8080/ 访问出404,不知道哪错了
- ssh: connect to host gitee.com port 22: Connection timed out fatal: Could not read from remote repos
- CTFHUBWeb技能树——密码口令writeup 附常见网络平台默认密码
- 虚拟化:gva、gpa、hva、hpa转化
- 转转支付网关之注解式HTTP客户端
- 小米平板4软件提取包_小米三大法宝:软件、硬件和服务;以及他的4条成功经验|小米手机|智能手机|手机...
- linux磁盘挂载方式mount
- 湖南多校对抗赛(2015.03.28) H	 SG Value
- java double转float_如何将double转换成float类型
- 如何往数据库快速插入百万条数据
- PDF通用工具其他下载地址
- 塔式、机架式、刀片式服务器区别以及特点
- php跨域解决办法,PHP跨域问题解决方案
热门文章
- JavaScript基本语法2
- flutter的四种模式/application/plugin/package/module,flutter调用原生的方法
- 在vue.js中如何导出Excel表格
- 撤销工作表保护原密码_批量解除工作表保护,和批量执行保护一样简单
- css 垂直居中_当面试官问起CSS布局之水平垂直居中时~~
- php7.4报错:Trying to access array offset on value of type null
- proto3文件定义Demo-用户表单条、多条、所有、编辑
- JMeter接口测试入门
- git clone 失败_鲜为人知的Git功能——Git Worktree工作树
- 2020全国计算机二级office大纲,2018-2020年(最新)全国计算机等级考试二级MS Office高级应用考试大纲...