美文网首页
PHP编码规范-PSR0解读

PHP编码规范-PSR0解读

作者: 益初 | 来源:发表于2017-01-08 22:52 被阅读0次

很多时候,我们可以看到国外的框架有有很多特别的写法,但是我们却不明其为什么要这么写,其实他们都是规范于PSR标准。
PSR标准,是又PHP-FIG制定的PHP编码规范

概述

从官方我们可以看到,目前审核通过的规范一共有8套。规范1-4常常被我们在各种文档中看到,但是这些规范的包含的什么,我们却很少知道,这里我就简单的整理一下。

已接受的方案

PSR-0 Basic Coding Standard 基本编码标准

标准内容

1.概述

  • 文件 必须<?php<?= 作为开始或者结束标签。
  • PHP代码文件 必须 使用UTF-8不带BOM头的编码格式。
  • 文件 应该 声明出代码的类型(比如 function,class,constants,其他...) 或者 声明出会产生的副作用(输出内容,更改配置)之一。而且不能两个声明一起出现。
  • 命名空间和类 必须 符合一个自动加载规范 PSR-0或者PSR-4。注: PIG官方已经标注PSR-0为过时的规范。
  • class名 必须 声明为 StudlyCaps。 大驼峰(首字母大写的驼峰)
  • method名 必须 声明为 camelCase。小驼峰(首字母小写的驼峰)

2.1 PHP Tags

PHP代码 必须 使用长标签 <php ?> 或者短标签<?= ?>

2.2 Character Encoding

PHP代码 必须 使用 不带BOM头的UTF-8编码

2.3 Side Effects

声明文件 应该 不包含会有产生副作用的代码。有产生副作用的代码也不应该包含有声明的情况。

“Side effects” include but are not limited to: generating output, explicit use of require
or include
, connecting to external services, modifying ini settings, emitting errors or exceptions, modifying global or static variables, reading from or writing to a file, and so on.
副作用:包含但不仅限于生成输出,包含 require或者include,连接外部服务器,改变php.ini设置,限制错误信息输出,改变全局或者静态变量,读取或者写入文件。

下面是一个不遵守这规范的例子

<?php
// side effect: change ini settings 副作用:改变ini设置
ini_set('error_reporting', E_ALL);
// side effect: loads a fileinclude "file.php"; 副作用:包含文件
// side effect: generates output 副作用:生成输出
echo "<html>\n";
// declaration 定义:函数
function foo(){ 
// function body
}

下面是一个符合标准的例子,定义一个函数,没有产生副作用的代码

<?php
// declaration 声明foo函数
function foo(){ 
// function body
}
// conditional declaration is *not* a side effect 条件判断不会产生副作用
if (! function_exists('bar')) {
    function bar() { 
    // function body   
    }
}

2.4 Namespace and Class Names

Namespaces和classes名 必须 符合一种自动加载机制。PSR-0或者PSR-4
这其中包含了: 每一个class必须独占一个文件

class names 必须 被命名为 ```StudlyCaps````.
如果代码运行环境是PHP5.3或者更新的,必须使用格式化的namespaces

举个栗子

<?php
// PHP 5.3 and later:
namespace Vendor\Model;
class Foo
{
}

运行环境是5.2或者更古老的,应该 使用伪命名空间

<?php
// PHP 5.2.x and earlier:
//在PSR-0中 下划线"_"会自动被转换成DS "/".用这个原理来自动加载Vendor/Model/Foo文件
class Vendor_Model_Foo 
{
}

2.5 Class Constants, Properties, and Methods

这里的"class"指所有的 classer, interfaces, traits

  • Constants 常量
    class常亮 必须被定义为全大写
<?php
namespace Vendor\Model;
class Foo
{
    const VERSION = '1.0';
    const DATE_APPROVED = '2012-06-01';
}

This guide intentionally avoids any recommendation regarding the use of$StudlyCaps
, $camelCase
, or $under_score
property names.
Whatever naming convention is used SHOULD be applied consistently within a reasonable scope. That scope may be vendor-level, package-level, class-level, or method-level.

我大概把他理解为 每一种命名规范至少在某一组织下保持一致

方法名 必须 声明为camelCase

这里就是PSR-1规范的全部内容了,其中classes需要联系着PSR-0或者PSR-4来看。

相关文章

  • PHP编码规范-PSR0解读

    很多时候,我们可以看到国外的框架有有很多特别的写法,但是我们却不明其为什么要这么写,其实他们都是规范于PSR标准。...

  • php编码规范(转)

    php编码规范

  • PHP PSR-1 Basic Coding Standard

    PSR-1 对基础的编码进行的规范. 规范总览 PHP 源文件只使用

  • PHP编码规范

    目的 为了更好的提高技术部的工作效率,保证开发的有效性和合理性,并可最大程度的提高程序代码的可读性和可重复利用性,...

  • PHP 编码规范

    https://www.php-fig.org/psr/psr-2/ pSR-0 & PSR-4 (自动加载标准)...

  • PHP编码规范

    前言:无规不成方圆 ,在很多情况下都是如此,生活如是、职场如是、代码亦如是。刚工作之初,代码总是写的很随意,还乐此...

  • PHP编码规范

    编程规范在团体开发中能使程序员按照统一标准编程,消除了混乱和迷茫,能使他们将精力聚焦于更重要的事情,而不是变量如何...

  • PHP编码规范

    转自:https://gold.xitu.io/post/589d7771128fe100580e7bcc 为什么...

  • PHP编码规范

    为什么需要编码规范? 为了提高工作效率,保证开发的有效性和合理性。 为了提高代码可读性和可重复利用性,从而节约沟通...

  • PHP编码规范

    整理自 PHP 标准规范 作为程序员来说,采用统一的编码风格是非常重要的。这将给未来代码的编写、阅读节省大量时间。...

网友评论

      本文标题:PHP编码规范-PSR0解读

      本文链接:https://www.haomeiwen.com/subject/xuhcbttx.html