考查结果

indent_type:
    tab: 7
    2: 1
    4: 14
line_length_limit_soft:
    ?: 2
    no: 3
    75: 4
    80: 6
    85: 1
    100: 1
    120: 4
    150: 1
line_length_limit_hard:
    ?: 2
    no: 11
    85: 4
    100: 3
    120: 2
class_names:
    ?: 1
    lower: 1
    lower_under: 1
    studly: 19
class_brace_line:
    next: 16
    same: 6
constant_names:
    upper: 22
true_false_null:
    lower: 19
    upper: 3
method_names:
    camel: 21
    lower_under: 1
method_brace_line:
    next: 15
    same: 7
control_brace_line:
    next: 4
    same: 18
control_space_after:
    no: 2
    yes: 20
always_use_control_braces:
    no: 3
    yes: 19
else_elseif_line:
    next: 6
    same: 16
case_break_indent_from_switch:
    0/1: 4
    1/1: 4
    1/2: 14
function_space_after:
    no: 22
closing_php_tag_required:
    no: 19
    yes: 3
line_endings:
    ?: 5
    LF: 17
static_or_visibility_first:
    ?: 5
    either: 7
    static: 4
    visibility: 6
control_space_parens:
    ?: 1
    no: 19
    yes: 2
blank_line_after_php:
    ?: 1
    no: 13
    yes: 8
class_method_control_brace:
    next/next/next: 4
    next/next/same: 11
    next/same/same: 1
    same/same/same: 6

文书档案仓库地址: PS冠道标准普通话版
PS奇骏-0机关加载 PSQashqai-1基本代码标准 PSKoleos-2代码样式 PS奥迪Q5-3日志接口 干什么标准
摘录翻译了法定的一句话
本集体目的在于通过座谈大家代码项指标协作点以搜索一个合作编制程序的方法。
在那想到了一篇小说《谷歌为啥要实践从严的代码标准》中有那样一段话:
复制代码 代码如下:
在谷歌(GoogleState of Qatar,小编得以查看别的的代码,进入全部谷歌(Google卡塔尔(قطر‎的代码库,笔者有权查看它们。事实上,这种权力是少之又少人能抱有的。可是,让作者感觉欣喜的却是,如此多的编码标准—缩进,命名,文件构造,注释风格—那全体让本人始料不比的轻便的开卷狂妄一段代码,并私下的看懂它们。那让本身震憾—因为自身认为那个规范是不足挂齿的东西。它们不也许有那般大的效用—但它们却起到了如此大的效应。当您开采只经过看程序的骨干语法布局就能够读懂一段代码,这种日子上的节约不得不令人感动!
各位看官作者就不要多说关于标准的事务了。 写在终极
标准不是无条件的,当然你也能够筛选本身的措施,但利用标准会让您的协作更轻易。近期各个更今世化应用的编辑撰写已不像早先,一个选取平日都有非常的多的模块组合,就算不举办标准,只会让整个项目的精晓和维系特别复杂。
若使用了专门的职业,对品种和协和的低价当然无庸赘述的。全体已选择的标准参照他事他说加以考察:
代码样式标准
本指南的准备是为着减小差异开垦者在浏览代码时减弱认识的差异。
为此罗列一组怎么样格式化PHP代码的共用准则。
种种成员项指标共性组成了本文的体制法规。当不一样的开采者在差异的类型中搭档时,将会在这里些分裂的门类中使用二个齐声的职业。
由此,本指南的裨益不在于法规本人,而介于共用那几个准则。 在 奥迪Q3FC
2119中的天性关键词”必需”,“供给”,“不会”,“应当”,“不应”,“推荐”,“能够”在这里文档中将被用来说述。
1. 大纲 代码必须服从 PSRAV4-1。
代码必需利用4个空格的缩进,实际不是制表符。
一行代码长度不应硬性限定;软约束必需为1十多少个字符;也相应是82个字符或许更加少。
在namespace注脚上边必需有叁个空行,並且use声北齐码块上面也必需有二个空行。
类的左花括号必得置于下一行,右花括号必得放在类主体的下一行。
方法的左花括号必需放在下一行,右花括号必得放在方法主体下边。
全体的性能和艺术必需有可以预知性(译者注:Public, Protect,
Private卡塔尔国表明;abstract和final注明必需在可知性以前;static注明必需在可以预知性之后。
调节构造的严重性词必需在后头有叁个空格; 方法和函数不可有。
调节构造的左花括号必得放在相符行,右花括号必需放在调控焦点的下一行。
调控布局的左括号前边不可有空格,右括号以前不得有空格。

4.2. 属性

附录A 调查

In writing this style guide, the group took a survey of member projects
to determine common practices. The survey is retained herein for
posterity.

留意:只用空格,不和制表符混合使用,将会对防止代码差别,补丁,历史和注释中的一些标题有支持。使用空格还是能使调治细微的缩进来改进行间对齐变得非常简单。

{

文中提到的首要词 “MUST 必须”, “MUST NOT 必得不”, “REQUIRED 必得”, “SHALL
会”, “SHALL NOT 不会”, “SHOULD 应该”, “SHOULD NOT 不应有”, “RECOMMENDED
推荐的”, “MAY 恐怕”, 和 “OPTIONAL 可选的” 在SportageFC 2119 中有实际描述.

function_space_after: 函数调用的函数名和左括号是还是不是有空格?

本节大家将会谈论一些着力的代码标准难点,以此作为以后商酌更加高等其余代码分享和才能互用的底子。

Namespace 和 Use 声明

  1. namespace 申明之后必需有空行。
  2. 抱有use 表明,必须在namespace证明之后。
  3. 种种证明必得独立接收三个use。
  4. use证明区之后必得有二个空行。

例如:

<?php
namespace Vendor\Package;

use FooClass;
use BarClass as Bar;
use OtherVendor\OtherPackage\BazClass;

// ... additional PHP code ...

line_length_limit_hard: 行长度的”硬”节制,用字符。 ? =
不表示依旧数字, no 意为不限定.

}

结语

本指南特意忽视了不菲风格和实施。蕴涵但不贬抑:

  • 宣称全局变量和全局常量。
  • 扬言函数。
  • 操作符和赋值。
  • 行间对齐。
  • 评释和文书档案区。
  • 类名前后缀。
  • 精品实行。

Future recommendations MAY revise and extend this guide to address those
or other elements of style and practice.

三个use关键字必需只用于三个宣称。

// catch body

例子

下边是三个总结的例子,能够支持您对准则有三个大要的认知。

<?php
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
    }
}

行间对齐

namespace VendorPackage;

if, elseif, else

if 构造如下所示。注意括号、空格、花括号的职分;同一时候注意 else 和 elseif
与前有个别的 } 在同一行。

<?php
if ($expr1) {
    // if body
} elseif ($expr2) {
    // elseif body
} else {
    // else body;
}

elseif关键字不应当被 else if 取代。

行实际尺寸不应超越柒拾几个字符;较长的行应当被拆分成多个不超过七十八个字符的存续行。

把闭包作为二个参数在函数或许措施中调用时,依然要信守上述法则。

try, catch

try-catch区块如下所示。 注意括号、空格和花括号的职位。

<?php
try {
    // try body
} catch (FirstExceptionType $e) {
    // catch body
} catch (OtherExceptionType $e) {
    // catch body
}

至上试行

参数列表能够被拆分成七个缩进了二遍的子行。假使拆分成子行,列表中的第一项必得放在下一行,况兼每一行必得只可以有三个参数。

Closure 闭包

扬言闭包必得在function关键字后留二个空格,在use关键字上下各留一个空格。

左花括号必得在同等行, 右花括号必需在body的下一行。

参数或变量列表的左括号后 和 右括号前必需未有空格。

参数和变量列表的逗号前必须未有空格,各样逗号后必需有贰个空格。

有私下认可值的参数必得排在最后。

闭包的注明如下所示。 注意括号,逗号,空格和花括号的职位:

<?php
$closureWithArgs = function ($arg1, $arg2) {
    // body
};

$closureWithArgsAndVars = function ($arg1, $arg2) use ($var1, $var2) {
    // body
};

参数列表和变量列表能够拆分到多行,每种子行有一层缩进。
这么做的时候,第二个列表成员必须独自占领一行,每行只好有八个列表成员。

参数或变量列表拆分为多行时,到了列表的尾声, 右括号 和
左花括号必需放在相似行,中间有一个空格。

例子:

<?php
$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
};

注意:当闭包被直接充任函数或措施调用的参数时,以上法规平等适用。

<?php
$foo->bar(
    $arg1,
    function ($arg2) use ($var1) {
        // body
    },
    $arg3
);

附录A
调查为了写那么些风格指南,大家运用了检察个品种以分明协作的做法。这一个应用商讨在此边供客人查看。

public function aVeryLongMethodName(

关键词(保留字) 和 true/false/null

  1. PHP保留字必须小写.
  2. PHP常量 true, false和 null 必需小写.

A.1.
考察数据url,
Calisthenics for
PHP,.
侦查验明indent_type: 缩进类型。 tab = “使用制表符”,2 or 4 = “空格数量”

4.3. 方法(method)

查明数量

url,http://www.horde.org/apps/horde/docs/CODING_STANDARDS,http://pear.php.net/manual/en/standards.php,http://solarphp.com/manual/appendix-standards.style,http://framework.zend.com/manual/en/coding-standard.html,http://symfony.com/doc/2.0/contributing/code/standards.html,http://www.ppi.io/docs/coding-standards.html,https://github.com/ezsystems/ezp-next/wiki/codingstandards,http://book.cakephp.org/2.0/en/contributing/cakephp-coding-conventions.html,https://github.com/UnionOfRAD/lithium/wiki/Spec%3A-Coding,http://drupal.org/coding-standards,http://code.google.com/p/sabredav/,http://area51.phpbb.com/docs/31x/coding-guidelines.html,https://docs.google.com/a/zikula.org/document/edit?authkey=CPCU0Us&hgd=1&id=1fcqb93Sn-hR9c0mkN6m_tyWnmEvoswKBtSc0tKkZmJA,http://www.chisimba.com,n/a,https://github.com/Respect/project-info/blob/master/coding-standards-sample.php,n/a,Object Calisthenics for PHP,http://doc.nette.org/en/coding-standard,http://flow3.typo3.org,https://github.com/propelorm/Propel2/wiki/Coding-Standards,http://developer.joomla.org/coding-standards.html
voting,yes,yes,yes,yes,yes,yes,yes,yes,yes,yes,yes,yes,yes,yes,yes,no,no,no,?,yes,no,yes
indent_type,4,4,4,4,4,tab,4,tab,tab,2,4,tab,4,4,4,4,4,4,tab,tab,4,tab
line_length_limit_soft,75,75,75,75,no,85,120,120,80,80,80,no,100,80,80,?,?,120,80,120,no,150
line_length_limit_hard,85,85,85,85,no,no,no,no,100,?,no,no,no,100,100,?,120,120,no,no,no,no
class_names,studly,studly,studly,studly,studly,studly,studly,studly,studly,studly,studly,lower_under,studly,lower,studly,studly,studly,studly,?,studly,studly,studly
class_brace_line,next,next,next,next,next,same,next,same,same,same,same,next,next,next,next,next,next,next,next,same,next,next
constant_names,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper,upper
true_false_null,lower,lower,lower,lower,lower,lower,lower,lower,lower,upper,lower,lower,lower,upper,lower,lower,lower,lower,lower,upper,lower,lower
method_names,camel,camel,camel,camel,camel,camel,camel,camel,camel,camel,camel,lower_under,camel,camel,camel,camel,camel,camel,camel,camel,camel,camel
method_brace_line,next,next,next,next,next,same,next,same,same,same,same,next,next,same,next,next,next,next,next,same,next,next
control_brace_line,same,same,same,same,same,same,next,same,same,same,same,next,same,same,next,same,same,same,same,same,same,next
control_space_after,yes,yes,yes,yes,yes,no,yes,yes,yes,yes,no,yes,yes,yes,yes,yes,yes,yes,yes,yes,yes,yes
always_use_control_braces,yes,yes,yes,yes,yes,yes,no,yes,yes,yes,no,yes,yes,yes,yes,no,yes,yes,yes,yes,yes,yes
else_elseif_line,same,same,same,same,same,same,next,same,same,next,same,next,same,next,next,same,same,same,same,same,same,next
case_break_indent_from_switch,0/1,0/1,0/1,1/2,1/2,1/2,1/2,1/1,1/1,1/2,1/2,1/1,1/2,1/2,1/2,1/2,1/2,1/2,0/1,1/1,1/2,1/2
function_space_after,no,no,no,no,no,no,no,no,no,no,no,no,no,no,no,no,no,no,no,no,no,no
closing_php_tag_required,no,no,no,no,no,no,no,no,yes,no,no,no,no,yes,no,no,no,no,no,yes,no,no
line_endings,LF,LF,LF,LF,LF,LF,LF,LF,?,LF,?,LF,LF,LF,LF,?,,LF,?,LF,LF,LF
static_or_visibility_first,static,?,static,either,either,either,visibility,visibility,visibility,either,static,either,?,visibility,?,?,either,either,visibility,visibility,static,?
control_space_parens,no,no,no,no,no,no,yes,no,no,no,no,no,no,yes,?,no,no,no,no,no,no,no
blank_line_after_php,no,no,no,no,yes,no,no,no,no,yes,yes,no,no,yes,?,yes,yes,no,yes,no,yes,no
class_method_control_brace,next/next/same,next/next/same,next/next/same,next/next/same,next/next/same,same/same/same,next/next/next,same/same/same,same/same/same,same/same/same,same/same/same,next/next/next,next/next/same,next/same/same,next/next/next,next/next/same,next/next/same,next/next/same,next/next/same,same/same/same,next/next/same,next/next/next

5.1. if,elseif,else

use FooInterface;

继承 和 实现

extends 和 implements 关键字必得和类名在同一行评释。

类的 { 必需独自据有一行; } 必需在body的下一行。

<?php
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
下一行,每行只好有一个接口。

<?php
namespace Vendor\Package;

use FooClass;
use BarClass as Bar;
use OtherVendor\OtherPackage\BazClass;

class ClassName extends ParentClass implements
    \ArrayAccess,
    \Countable,
    \Serializable
{
    // constants, properties, methods
}
  1. Namespace和Use评释假如存在,namespace注明之后必需有三个空行。

public function fooBarBaz($arg1, &$arg2, $arg3 = [])

方法

具备办法都必得申明可以见到性。

不应该经过前缀下划线来标示protected和private的艺术。

扬言方法时,方法名的后必需未有空格。 { 必需在相似行, }
必需在body的下一行。 (后必得未有空格,State of Qatar 前必需未有空格。

多少个方法注脚的事举个例子下,注意 小括号,逗号,空格 和 花括号 的岗位:

<?php
namespace Vendor\Package;

class ClassName
{
    public function fooBarBaz($arg1, &$arg2, $arg3 = [])
    {
        // method body
    }
}

类的左花括号必须放在上边自成一行;右花括号必得放在类主体的前边自成一行。

$longArgument,

骨干法则

use FooClass;use BarClass as Bar;use
OtherVendor\OtherPackage\BazClass;

全局变量和全局常量的申明

主导编码标准

代码必需比照PSLacrosse-1的条目款项。

方式中有私下认可值的参数必需放在参数列表的结尾面。

}

那边的品格约定衍生自若干成员项目。指南作者们在八个等级次序中搭档,推动了那么些指引条目款项名落孙山。
指南的关键在于分享,并非平整本身。

从今以往的建议方可修正和扩大该指南以满意那些或别的风格的因素和实行。

namespace VendorModel;

switch, case

Switch布局如下所示。注意括号、空格和花括号的职位。 case
语句相对于switch必需有二个缩进, break关键字
也许此外终结性的重要字必需和case body在同一缩进层级。在非空的case
body,若无终结性语句,必须抬高注释 // no break

<?php
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;
}

true_false_null: 全校写或许全大写?

}

措施参数

形式的形参列表中,
各个逗号前必须没有空格。有暗中同意值的参数必得在参数列表的末梢。

<?php
namespace Vendor\Package;

class ClassName
{
    public function foo($arg1, &$arg2, $arg3 = [])
    {
        // method body
    }
}

参数列表能够切分为多行,每种子行要有几个缩进。即使那样做,第三个参数必得独占一行,每行只好有叁个参数。

参数列表切分为多行时,右括号卡塔尔和左花括号{必得在相似行,此前必需有一个空格。

<?php
namespace Vendor\Package;

class ClassName
{
    public function aVeryLongMethodName(
        ClassTypeHint $arg1,
        &$arg2,
        array $arg3 = []
    ) {
        // method body
    }
}

2.4. 缩进代码必须运用4个空格的缩进,并且不可使用制表符作为缩进。

办法(method卡塔尔(قطر‎的左花括号必需置于其注明下边自成一行,右花括号则必须置于方法主体的下一行。

类, 属性 和 方法

这里的“类”包括 class、interface 和 trait。

class ClassName{ public function fooBarBaz($arg1, &$arg2, $arg3 = [])
{ // method body }}

function autoload($className)

for

for 构造如下所示。 注意括号、空格和花括号之处。

<?php
for ($i = 0; $i < 10; $i++) {
    // for body
}

上面是一个参数和变量列表被分割成多行的现身说法。复制代码 代码如下:

$muchLongerArgument

调控构造

调整构造经常固守以下风格:

  1. 调控布局关键词后必需有壹个空格。
  2. 左括号后必得未有空格。
  3. 右括号前必需未有空格。
  4. 又括号和左花括号之间必需有一个空格。
  5. body必需有一层缩进。
  6. 右花括号必须在body下一行。
  7. 各种调整结构的body必得用花括号括起来。
    即保险外观统一,又减少了拉长新行时引进的不当。

class_method_control_brace: 左花括号在类,方法和调整布局中的地点。

短语副功效(side effects卡塔尔(قطر‎的意味是 在含蓄文件时
所实施的逻辑与所注脚的类(classState of Qatar,函数(functionState of Qatar,常量(constant卡塔尔等尚未一向的涉嫌。

文件

  1. 具备文件必需运用 Unix LF (linefeedState of Qatar 换行。
  2. 负有PHP文件必须利用单个空行停止。
  3. 只含有PHP的代码必需忽视php截至标志 ? >。

class ClassName extends ParentClass implements \ArrayAccess,
\Countable{ // constants, properties, methods}

类(class卡塔尔中的常量必需只由大写字母和下划线(_)组成。

abstract, final 和 static

abstract和final注解必得在可以看到性此前宣称。
static阐明必须在可知性之后。

<?php
namespace Vendor\Package;

abstract class ClassName
{
    protected static $foo;

    abstract protected function zim();

    final public static function bar()
    {
        // method body
    }
}

复制代码 代码如下:

那几个示例中总结显示了上文中提到的有些规规矩矩:

主意和函数调用

写方法或函数调用时,方法/函数名 和 左括号( 之间,必须未有空格, 右括号
)在此之前必需未有空格。在参数列表中,逗号间必得未有逗号,每一种逗号后必须有叁个空格。

<?php
$foo->bar(
    $longArgument,
    $longerArgument,
    $muchLongerArgument
);

复制代码 代码如下:

include “file.php”;

缩进

  1. 代码必得采纳 4 空格的缩进, 必需毫无tab作为缩进。

留神:只使用空格,不用tab,有利于制止diffs,patches,
history和annotations的难题。使用空格也助长对齐。

复制代码 代码如下:

{

foreach

foreach 构造如下所示。 注意括号、空格和花括号的职位。

<?php
foreach ($iterable as $key => $value) {
    // foreach body
}

$shortArgs_longVars = function use ( $longVar1, $longerVar2,
$muchLongerVar3State of Qatar { //
body};注意如果在函数或许措施中把闭包作为二个参数调用,如上格式准绳同样适用。复制代码 代码如下:bar( $arg1, function { //
body }, $arg3State of Qatar;

}

while, do while

while构造如下所示。 注意括号、空格和花括号的职位。

<?php
while ($expr) {
    // structure body
}

do-while接口如下所示。 注意括号、空格和花括号的职分。

<?php
do {
    // structure body;
} while ($expr);

4.5. abstract,final和
static假如存在,abstract和final证明必得放在可以预知性表明前边。

case 3:

本指罗列了通用的PHP代码格式准则和建议,目的在于削减差异笔者的编码风格差异带给的认识障碍。

复制代码 代码如下:

final public static function bar()

属性

不无属性都必须要评释 visibility(可以知道性)。

Var 关键字必需不能够用于注脚属性。

每行必得只声澳优(Ausnutria Hyproca卡塔尔(قطر‎个属性。

不应当经过前缀下划线来标示protected和private的特性。

例:

<?php
namespace Vendor\Package;

class ClassName
{
    public $foo = null;
}

class ClassName{ public $foo = null;}

规范

概览

  1. 代码必须固守 “根基编码典型” PSPAJERO [PSR-1]。
  2. 代码缩进必需选拔 4 空格,并不是tab。
  3. 行长度必得无硬性节制; 软性约束必得为120字符;应该少于等于80字。
  4. namespace表明后必得有二个空行,use评释后也必需有七个空行。
  5. 类的{ 必须在类名的下一行, }必得在body的下一行。
  6. 形式的 { 必需在措施具名的下一行,} 必得在body的下一行。
  7. 持有的习性和方式都要设置可知性; abstract和
    final必需在可知性早前宣称;static 必需在可以见到性后声称。
  8. 构造决定首要词后必得有叁个空格; 方法和函数必需未有空格。
  9. 组织决定的 { 必得在同一行,} 必得在body的下一行。
  10. 布局决定的 ( 后必需有空格, 布局决定的 卡塔尔(قطر‎ 前必需未有空格。

三个switch构造看起来应当像下边那样。注意括号,空格和花括号。case语句必需从switch处缩进,并且break关键字必需和case主体缩进在同级。假如一个非空的case主体往下跌空则必得有三个近乎//
no break的阐明。复制代码
代码如下:复制代码 代码如下:复制代码 代码如下:

一行代码的尺寸不提出超越七十九个字符;较长的行提议拆分成三个不抢先77个字符的子行。

  1. 行长度必得未有硬性限定。
  2. 长度的软性约束必须为120字符;自动代码风格检查必需将120字设置为警示,必需不能够安装为错误。
  3. 行不应有超过80字符;超过那个长度的行应该切分为多个不超过80字符的行。
  4. 非空行的告竣必需未有跟随空格。
  5. 为加强可读性,可扩充空行来表唐宋码的关联性。
  6. 每行富含的说话必须不可能赶过1条。

4.1. 扩展和一而再三个类的extends和implements关键词必得和类名在同一行。

case 0:

检察证实

indent_type: The type of indenting. tab = “Use a tab”, 2 or 4 = “number
of spaces”

line_length_limit_soft: The “soft” line length limit, in characters.
? = not discernible or no response, no means no limit.

line_length_limit_hard: The “hard” line length limit, in characters.
? = not discernible or no response, no means no limit.

class_names: How classes are named. lower = lowercase only,
lower_under = lowercase with underscore separators, studly =
StudlyCase.

class_brace_line: Does the opening brace for a class go on the same
line as the class keyword, or on the next line after it?

constant_names: How are class constants named? upper = Uppercase with
underscore separators.

true_false_null: Are the true, false, and null keywords spelled as all
lower case, or all upper case?

method_names: How are methods named? camel = camelCase, lower_under =
lowercase with underscore separators.

method_brace_line: Does the opening brace for a method go on the same
line as the method name, or on the next line?

control_brace_line: Does the opening brace for a control structure go
on the same line, or on the next line?

control_space_after: Is there a space after the control structure
keyword?

always_use_control_braces: Do control structures always use braces?

else_elseif_line: When using else or elseif, does it go on the same
line as the previous closing brace, or does it go on the next line?

case_break_indent_from_switch: How many times are case and break
indented from an opening switch statement?

function_space_after: Do function calls have a space after the
function name and before the opening parenthesis?

closing_php_tag_required: In files containing only PHP, is the
closing ?> tag required?

line_endings: What type of line ending is used?

static_or_visibility_first: When declaring a method, does static come
first, or does the visibility come first?

control_space_parens: In a control structure expression, is there a
space after the opening parenthesis and a space before the closing
parenthesis? yes = if ( expr),no=if(expr).

blank_line_after_php: Is there a blank line after the opening PHP
tag?

class_method_control_brace: A summary of what line the opening braces
go on for classes, methods, and control structures.

method_brace_line: 方法的左花括号在同一行?

持有PHP源文件必得以三个空行截至。

var关键词不可用来声称属性。

};

5.5. foreach

汉兰达FC 2119中的必需(MUST卡塔尔(قطر‎,不可(MUST NOT卡塔尔国,提议(SHOULD卡塔尔(قطر‎,不提出(SHOULD
NOT卡塔尔国,能够/只怕(MAY卡塔尔等要害词就要本节用来做一些解释性的叙说。

use FooClass;use BarClass as Bar;use
OtherVendor\OtherPackage\BazClass;

1.1. 示例

  1. 调控构造对于调整结构的样式法规归纳如下:

) {

有着PHP文件必得以多少个空行结束。

代码必须信守 PS福特Explorer-1 中的全部准绳。

5.2. switch,case

源文件中php代码的编码格式必需只利用不带字节顺序标志(BOM卡塔尔的UTF-8。

假定存在,static注解必需随着可以预知性申明。

function foo()

  1. 闭包

那意味多少个源文件中必须要有一个类(class卡塔尔,何况每一种类(class卡塔尔(قطر‎至少要有一流空间名(namespace):即贰个一级的团伙名(vendor
name卡塔尔。

类名给你前缀和后缀

当参数列表被拆分成八个子行,右括号和左花括号之间必得又三个空格並且自成一行。

纯PHP代码的文书关闭标签?>必得回顾

// PHP 5.2.x 及之前:

参数列表和变量列表的左括号之后不可有空格,其右括号在此之前也不行有空格。

副成效(side
effectsState of Qatar包涵但不囿于于:发生输出,显式地采纳require或include,连接外界服务,修改ini配置,触发错误或非常,纠正全局也许静态变量,读取或改换文件等等

参数和变量列表能够被分为五个带一遍缩进的接续行。借使这么做,列表的率先项必得放在下一行,而且一行必得只放三个参数或变量。

bar(

主意证明

) {

line_endings: 使用何种的行甘休符?

调整布局的左括号之后不可有空格。

closing_php_tag_required: 如过是纯PHP文件,关闭标签?>是不是供给?

下边是一个仅富含评释的示范文件;即应提倡的例证:

4.6.
调用方法和函数要调用一个办法或函数,在艺术照旧函数名和左括号之间不得有空格,左括号过后不可有空格,右括号以前不得有空格。函数列表中,逗号以前不得有空格,逗号之后必需有叁个空格。

4.1. 常量

final public static function bar() { // method body }}

function bar()

在参数列表和变量列表中,逗号早先不得有空格,逗号之后必需有空格。

namespace VendorPackage;

$longArgs_shortVars = function ( $longArgument, $longerArgument,
$muchLongerArgument) use { // body};

2.2 源文件

PHP常量true, false和null必须使用小写。

public $foo = null;

2.3. 行行长度不得有硬限定。

}

空行能够用来改革可读性和区分相关的代码块。

namespace VendorPackage;

艺术名在声明之后不可跟随三个空格。左花括号必需放在上面自成一行,而且右花括号必得放在方法主体的上面自成一行。左括号后面不可有空格,右括号前方不可有空格。

// 副作用:修改了ini配置

5.4.
for二个for语句看起来应当像上边那样。注意括号,空格和花括号的职位。复制代码 代码如下:

// body

一行不应多于叁个口舌。

},

2.2 文件全数的PHP文件必得使用Unix LF作为行结束符。

上边是二个do while循环控制结构的身体力行,注意在那之中括号,空格和花括号的岗位。

abstract protected function zim();

use OtherVendorOtherPackageBazClass;

一个措施定义看来应该像上边那样。 注意括号,逗号,空格和花括号:

$arg1,

复制代码 代码如下:

// structure body

$longArgs_longVars = function ( $longArgument, $longerArgument,
$muchLongerArgument) use ( $longVar1, $longerVar2, $muchLongerVar3) { //
body};

// body

复制代码 代码如下:

&$arg2,

行长度的软限定必得是1十多少个字符;对于软限定,自动样式检查器必需警报但不可报错。

} elseif ($a > $b) {

当参数列表被分成多行,右括号和左花括号必得夹带三个空格放在一块儿自成一行。

}

复制代码 代码如下:bar( $longArgument, $longerArgument,
$muchLongerArgumentState of Qatar;

{

// … additional PHP code …

// 方法主体部分

闭包带默许值的参数必得放在参数列表后边。

case 1:

4.2. 天性全体的性子必得表明可以见到性。

一行不可多于几个言辞。

左花括号必得在同等行,右花括号必得在主体的下一行。

// 方法主体部分

class ClassName extends ParentClass implements \ArrayAccess,
\Countable, \Serializable{ // constants, properties, methods}

$muchLongerArgument

abstract class ClassName{ protected static $foo;

echo ‘Default case’;

A.3. 考察结果indent_type: tab: 7 2: 1 4: 14line_length_limit_soft:
?: 2 no: 3 75: 4 80: 6 85: 1 100: 1 120: 4 150:
1line_length_limit_hard: ?: 2 no: 11 85: 4 100: 3 120: 2class_names:
?: 1 lower: 1 lower_under: 1 studly: 19class_brace_line: next: 16
same: 6constant_names: upper: 22true_false_null: lower: 19 upper:
3method_names: camel: 21 lower_under: 1method_brace_line: next: 15
same: 7control_brace_line: next: 4 same: 18control_space_after: no:
2 yes: 20always_use_control_braces: no: 3 yes: 19else_elseif_line:
next: 6 same: 16case_break_indent_from_switch: 0/1: 4 1/1: 4 1/2:
14function_space_after: no: 22closing_php_tag_required: no: 19 yes:
3line_endings: ?: 5 LF: 17static_or_visibility_first: ?: 5 either: 7
static: 4 visibility: 6control_space_parens: ?: 1 no: 19 yes:
2blank_line_after_php: ?: 1 no: 13 yes:
8class_method_control_brace: next/next/next: 4 next/next/same: 11
next/same/same: 1 same/same/same: 6

艺术名则必得使用camelCase(State of Qatar风格来声称。

属性名称不应使用单个下划线作为前缀来表明保护或个体的可以看到性。

} catch (FirstExceptionType $e) {

1.1. 示例本示例包括下面的一对法规轻便浮现:

// 条件式申明不算做是副成效

blank_line_after_php: PHP的启幕标签后边是或不是须要二个空行?

示例

constant_names: 类常量怎样命名?upper = 大写加下划线分隔符。

2.3. 副作用

static_or_visibility_first: 在定义方法的时候static和可以知道性何人在前头?

class Foo

class Foo extends Bar implements FooInterface{ public function
sampleFunction { if ; } elseif { $foo->bar; } else { BazClass::bar; }
}

措施名(method name卡塔尔国必得运用驼峰式(cameCase卡塔尔国写法(译者注:后文将平素用camelCase表示卡塔尔国。

主意名不应只行使单个下划线来表明是维护或个体的可知性。

具有的习性(propertyState of Qatar都必得证明其可以预知性。

control_space_after: 调节构造关键词后是不是有空格?

纯PHP代码源文件的闭馆标签?> 必需回顾。

全局变量和全局常量的注明

// 方法主体部分

一个言语不可注脚三个属性。

// no break

2.5. 根本词和 True/False/NullPHP keywords 必得利用小写。

$longArgument,

else_elseif_line: 当使用else和elseif,是还是不是位于同一行?

二个措施(method卡塔尔(قطر‎申明看来应该像上边那样。
注意括号,逗号,空格和花括号之处:

在use声大顺码块前边总得有一个空行。

上面是一个参数列表和变量列表被拆分成多个子行的示范。

参数列表能够被分成多少个有贰次缩进的两个三番两次行。假设如此做,列表的第一项必需放在下一行,并且每行必得只放二个参数。

{

$noArgs_longVars = function () use ( $longVar1, $longerVar2,
$muchLongerVar3) { // body};

namespacepackageClass_Name => /path/to/project/lib/vendor/namespace/package/Class/Name.php

操作符和赋值

$foo->bar($arg1);

注明和文书档案块

调整构造的代码主体必得开展二遍缩进。

line_length_limit_soft: 行长度的“软”节制,用字符。 ? = 不代表依旧数字
no 意为不限定.

调整结构的右括号和左花括号之间必得有贰个空格。

case_break_indent_from_switch:
case和break分别从swith语句处缩进多少次?

ZendMailMessage => /path/to/project/lib/vendor/Zend/Mail/Message.php

复制代码 代码如下:

ini_set(‘error_reporting’, E_ALL);

control_space_parens:
在调整布局表明式中,左括号后边和右括号前方是否要有二个空格?yes = if ,
no =if .

}

  1. 包含2.1 底工代码标准代码必需遵守 PSTiguan-1 的兼具规行矩步。

bar();

调整构造关键词之后必得有一个空格 左括号以后不可有空格
右括号早先不得有空格 在右括号和左花括号之间必需有叁个空格
代码主体必需有壹回缩进 右花括号必得注重的下一行
每一种协会的基点必得被括在花括号里。那构造看上去更标准,并且当加新行的时候可以裁减引进错误的大概性。

}

class ClassName{ public function foo($arg1, &$arg2, $arg3 = []) { //
method body }}

// 方法主体

要害词elseif应该取代else if使用以保持全部的垄断(monopolyState of Qatar入眼词像一个单词。

try {

implements四个列表能够被拆分为四个有一次缩进的接二连三行。即使这么做,列表的第一项必需求放在下一行,况兼每行必得唯有一个接口。

  1. 概述

三个闭包注脚看起来应当像上边那样。注意括号,空格和花括号之处。

从文件系统中加载源文件时,空间名(namespace卡塔尔国中的分隔符将被转变为
DIRECTOTucsonY_SEPARATOR。

final public static function bar() { // method body }}

行间对齐

三个天性注脚看起来应当上面那样的。

福寿康宁(implementState of Qatar列表能够被拆分为四个缩进了一次的子行。假诺要拆成七个子行,列表的第一项必定要放在下一行,并且每行必得独有多个接口(interface卡塔尔(قطر‎。

method_names: 方法名怎样命名?camel = 驼峰式, lower_under =
小写加下划线分隔符。

// body

当最终列表被分为多行,右括号和左花括号必得夹带三个空格放在一同自成一行。

  1. 调节布局

复制代码 代码如下:

批注和文书档案块

若是存在,全数的use评释必须放在namespace表明的底下。

空行能够用来增加可读性和界别相关代码块。

class ClassName{ public function aVeryLongMethodName( ClassTypeHint
$arg1, &$arg2, array $arg3 = [] ) { // method body }}

$noArgs_longVars = function () use (

一个foreach语句看起来应当像下边那样。注意括号,空格和花括号的岗位。复制代码 代码如下: $value卡塔尔 { // foreach
body}5.6. try, catch三个try
catch语句看起来应当像下边那样。注意括号,空格和花括号的职位。复制代码 代码如下:

// 声明

复制代码 代码如下:

$longerArgument,

class_brace_line: 类的左花括号是身处同一行?

下边是三个闭包的言传身教。注意括号,空格和花括号的岗位。

示例:

当列表(不管是参数照旧变量)最后被拆分成多少个子行,右括号和左花括号之间应当要有二个空格并且自成一行。

复制代码 代码如下:

  1. 类(class),属性(property)和方法(method)

class_names: 类名如何命名 lower = 只是小写, lower_under =
小写加下划线, studly = 骆驼型.

  1. 闭包

叁个if布局看起来应当像上边那样。注意括号,空格,花括号的地点;何况else和elseif和前贰当中央的右花括号在同一行。

};

  1. 类,属性和办法术语“类”指装有的类,接口和性情。

// for body

7.
定论在该指南开中学有众多风格的因素和做法有意被忽视掉。那个归纳但不囿于于:

  1. 结论

闭包在宣称时function关键词之后必需有多个空格,并且use以前也须要三个空格。

为了尽大概的升迁阅读别的人代码时的频率,上面例举了一层层的通用法规,特别是有关于PHP代码风格的。

4.3. 主意全部的秘籍必需评释可知性。

} while ($expr);

control_brace_line: 调控构造的左花括号在同一行?

use FooClass;

always_use_control_braces: 调节构造总是利用花括号?

echo ‘Third case, return instead of break’;

复制代码 代码如下:

5.3. while,do while

4.4.
办法参数在参数列表中,逗号此前不得有空格,逗号之后必定要有七个空格。

以上是大家为落到实处通用的机动加载而拟定的最低标准。你能够利用能够自行加载PHP
5.3类的SplClassLoader来测量试验你的代码是不是符合这么些规范。

在非空行前面不可有空格。

class ClassName

{

什么是psr0重申自动加载的艺术

在命名空间(namespace卡塔尔国的宣示上面必得有一行空行,何况在导入(use卡塔尔国的扬言下边也亟须有一行空行。

default:

return;

// 副成效:爆发了出口

调整构造的左括号过后不可有空格,右括号从前也不可有空格。

一心规范的命名空间(namespace卡塔尔(قطر‎和类(class卡塔尔从文件系统加载源文件时将会加上.php后缀。

// body

}

下边是多个if条件调整布局的身体力行,注意当中括号,空格和花括号的岗位。同不平日候注意else和elseif要和前一个尺码调节布局的右花括号在同一行。

}

}

源文件必得只行使和那三种标签。

class Vendor_Model_Foo

代码必须运用4个空格,且不可接收制表符来作为缩进。

上边是叁个既包蕴表明又有副功能的为人师表文件;即应防止的例子:

admin

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注