side effects php,PHP编码规范-PSR0解读

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

PSR标准,是又PHP-FIG制定的PHP编码规范

概述

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

ab3f63396f0f

已接受的方案

标准内容

1.概述

文件 必须 用 <?php 和 <?= 作为开始或者结束标签。

PHP代码文件 必须 使用UTF-8不带BOM头的编码格式。

文件 应该 声明出代码的类型(比如 function,class,constants,其他...) 或者 声明出会产生的副作用(输出内容,更改配置)之一。而且不能两个声明一起出现。

命名空间和类 必须 符合一个自动加载规范 PSR-0或者PSR-4。注: PIG官方已经标注PSR-0为过时的规范。

class名 必须 声明为 StudlyCaps。 大驼峰(首字母大写的驼峰)

method名 必须 声明为 camelCase。小驼峰(首字母小写的驼峰)

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

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

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

“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设置,限制错误信息输出,改变全局或者静态变量,读取或者写入文件。

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

// side effect: change ini settings 副作用:改变ini设置

ini_set('error_reporting', E_ALL);

// side effect: loads a fileinclude "file.php"; 副作用:包含文件

// side effect: generates output 副作用:生成输出

echo "\n";

// declaration 定义:函数

function foo(){

// function body

}

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

// declaration 声明foo函数

function foo(){

// function body

}

// conditional declaration is *not* a side effect 条件判断不会产生副作用

if (! function_exists('bar')) {

function bar() {

// function body

}

}

Namespaces和classes名 必须 符合一种自动加载机制。PSR-0或者PSR-4

这其中包含了: 每一个class必须独占一个文件

class names 必须 被命名为 ```StudlyCaps````.

如果代码运行环境是PHP5.3或者更新的,必须使用格式化的namespaces

举个栗子

// PHP 5.3 and later:

namespace Vendor\Model;

class Foo

{

}

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

// PHP 5.2.x and earlier:

//在PSR-0中 下划线"_"会自动被转换成DS "/".用这个原理来自动加载Vendor/Model/Foo文件

class Vendor_Model_Foo

{

}

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

Constants 常量

class常亮 必须被定义为全大写

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来看。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值