目录
本文主要和大家分享PHP代码样式风格规范,希望能帮助到大家。
一、基本约定
1、源文件
2、缩进
3、行
4、关键字 和 True/False/Null
5、命名
6、代码注释标签
7、业务模块
二、代码样式风格
1、命名空间(Namespace) 和 导入(Use)声明
2、类(class),属性(property)和方法(method)
3、控制结构
4、注释
5、空格
6、空行
PSR-4 规范
【补充】数组 的书写格式
首页 后端开发 php教程 PHP代码样式风格规范分享

PHP代码样式风格规范分享

Mar 05, 2018 am 10:30 AM
php 分享 规范

本文主要和大家分享PHP代码样式风格规范,希望能帮助到大家。

一、基本约定

1、源文件

(1)、纯PHP代码源文件只使用

(2)、源文件中PHP代码的编码格式必须是无BOM的UTF-8格式;

(3)、使用 Unix LF(换行符)作为行结束符;

(4)、一个源文件只做一种类型的声明,即,这个文件专门用来声明Class, 那个文件专门用来设置配置信息,别混在一起写;

2、缩进

使用Tab键来缩进,每个Tab键长度设置为4个空格;

3、行

一行推荐的是最多写120个字符,多于这个字符就应该换行了,一般的编辑器是可以设置的。

//wo

补一条 不出现横滚屏和竖滚屏,

4、关键字 和 True/False/Null

PHP的关键字,必须小写,boolean值:true,false,null 也必须小写。

下面是PHP的“关键字”,必须小写:

'__halt_compiler', 'abstract', 'and', 'array', 'as', 'break', 'callable', 'case', 'catch', 'class', 'clone', 'const', 'continue', 'declare', 'default', 'die', 'do', 'echo', 'else', 'elseif', 'empty', 'enddeclare', 'endfor', 'endforeach', 'endif', 'endswitch', 'endwhile', 'eval', 'exit', 'extends', 'final', 'for', 'foreach', 'function', 'global', 'goto', 'if', 'implements', 'include', 'include_once', 'instanceof', 'insteadof', 'interface', 'isset', 'list', 'namespace', 'new', 'or', 'print', 'private', 'protected', 'public', 'require', 'require_once', 'return', 'static', 'switch', 'throw', 'trait', 'try', 'unset', 'use', 'var', 'while', 'xor'

5、命名

(1)、类名 使用大驼峰式(StudlyCaps)写法;

(2)、(类的)方法名 使用小驼峰(cameCase)写法;

(3)、函数名使用 小写字母 + 下划线 写法,如 function http_send_post(); 

(4)、变量名 使用小驼峰写法,如 $userName;

6、代码注释标签

如 函数注释、变量注释等,常用标签有 @package、@var、@param、@return、@author、@todo、@throws

必须遵守 phpDocument 标签规则,不要另外去创造新的标签,更多标签查看 phpDocument官网

7、业务模块

(1)、涉及到多个数据表 更新/添加 操作时,最外层要用事务,保证数据库操作的原子性;

(2)、Model层,只做简单的数据表的查询;

(3)、业务逻辑统一封装到 Logic层;

(4)、控制器只做URL路由,不要当作 业务方法 调用;

(5)、控制器层不能出现SQL操作语句,如 ThinkPHP框架的 where()、order() 等模型方法,

即,控制器中,不要出现类似这样的SQL语句:D('XXX')->where()->order()->limit()->find();  

where()、order()、limit() 等SQL方法只能出现在 Model层、业务层!

二、代码样式风格

1、命名空间(Namespace) 和 导入(Use)声明

先简单文字描述下:

  1. 命名空间(namespace)的声明后面必须有一行空行;

  2. 所有的导入(use)声明必须放在命名空间(namespace)声明的下面;

  3. 一句声明中,必须只有一个导入(use)关键字;

  4. 在导入(use)声明代码块后面必须有一行空行;

用代码来说明下:

1

2

3

4

5

6

namespace Lib\Databases; // 下面必须空格一行

class Mysql {

}

namespace下空一行,才能使用use,再空一行,才能声明class

1

2

3

4

5

6

7

8

9

10

namespace Lib\Databases; // 下面必须空格一行

use FooInterface; // use 必须在namespace 后面声明

use BarClass as Bar;

use OtherVendor\OtherPackage\BazClass; // 下面必须空格一行

class Mysql {

}

2、类(class),属性(property)和方法(method)

(1)、继承(extends) 和实现(implement) 必须和 class name 写在一行。

1

2

3

4

5

6

namespace Lib\Databaes;

class Mysql extends ParentClass implements \PDO, \DB { // 写一行

}

(2)、属性(property)必须声明其可见性,到底是 public 还是 protected 还是 private,不能省略,也不能使用var, var是php老版本中的什么方式,等用于public。

1

2

3

4

5

6

7

8

namespace Lib\Databaes;

class Mysql extends ParentClass implements \PDO, \DB { // 写一行

public $foo = null;

private $name = 'yangyi';

protected $age = '17';

}

(3)、方法(method),必须 声明其可见性,到底是 public 还是 protected 还是 private,不能省略。如果有多个参数,第一个参数后紧接“,” ,再加一个空格:function_name ($par, $par2, $pa3), 如果参数有默认值,“=”左右各有一个空格分开。

1

2

3

4

5

6

7

8

namespace Lib\Databaes;

class Mysql extends ParentClass implements \PDO, \DB { // 写一行

public getInfo($name, $age, $gender = 1) { // 参数之间有一个空格。默认参数的“=”左右各有一个空格,) 与 { 之间有一个空格

}

}

(4)、当用到抽象(abstract)和终结(final)来做类声明时,它们必须放在可见性声明 (public 还是protected还是private)的前面。而当用到静态(static)来做类声明时,则必须放在可见性声明的后面。

直接上代码:

1

2

3

4

5

6

7

8

9

10

11

namespace Vendor\Package;

abstract class ClassName {

protected static $foo; // static放后面

abstract protected function zim(); // abstract放前面

final public static function bar() { // final放前面,static放最后。

// 方法主体部分

}

}

3、控制结构

控制接口,就是 if else while switch等。这一类的写法规范也是经常容易出现问题的,也要规范一下。

(1)、if,elseif,else写法,直接上规范代码吧:

1

2

3

4

5

6

7

8

if ($expr1) { // if 与 ( 之间有一个空格,) 与 { 之间有一个空格

} elseif ($expr2) { // elesif 连着写,与 ( 之间有一个空格,) 与 { 之间有一个空格

} else { // else 左右各一个空格

}

(2)、switch,case 注意空格和换行,还是直接上规范代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

switch ($expr) { // switch 与 ( 之间有一个空格,) 与 { 之间有一个空格

case 0:

echo 'First case, with a break'; // 对齐

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;

}

(3)、while,do while 的写法也是类似,上代码:

1

2

3

4

5

6

7

8

while ($expr) { // while 与 ( 之间有一个空格, ) 与 { 之间有一个空格

}

do { // do 与 { 之间有一个空格

} while ($expr); // while 左右各有一个空格

(4)、for的写法

1

2

3

4

for ($i = 0; $i < 10; $i++) { // for 与 ( 之间有一个空格,二元操作符 "="、"<" 左右各有一个空格,) 与 { 之间有一个空格

}

(5)、foreach的写法

1

2

3

4

foreach ($iterable as $key => $value) { // foreach 与 ( 之间有一个空格,"=>" 左右各有一个空格,) 与 { 之间有一个空格

 

}

(6)、try catch的写法

1

2

3

4

5

6

7

8

try { // try 右边有一个空格

} catch (FirstExceptionType $e) { // catch 与 ( 之间有一个空格,) 与 { 之间有一个空格

} catch (OtherExceptionType $e) { // catch 与 ( 之间有一个空格,) 与 { 之间有一个空格

}

4、注释

(1)、行注释

// 后面需要加一个空格;

如果 // 前面有非空字符,则 // 前面需要加一个空格;

(2)、函数注释

参数名、属性名、标签的文本 上下要对齐;

在第一个标签前加一个空行;

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

/**

* This is a sample function to illustrate additional PHP

* formatter options.

*

* @param $one The first parameter

* @param int $two The second parameter

* @param string $three The third parameter with a longer

* comment to illustrate wrapping.

* @return void

* @author phpgo.cnblogs.com

* @license GPL

*/

function foo($one, $two = 0, $three = "String") {

}

5、空格

(1)、赋值操作符(=,+= 等)、逻辑操作符(&&,||)、等号操作符(==,!=)、关系运算符(<,>,<=,>=)、按位操作符(&,|,^)、连接符(.) 左右各有一个空格;

(2)、if,else,elseif,while,do,switch,for,foreach,try,catch,finally 等 与 紧挨的左括号“(”之间有一个空格;

(3)、函数、方法的各个参数之间,逗号(",")后面有一个空格;

6、空行

(1)、所有左花括号 { 都不换行,并且 { 紧挨着的下方,一定不是空行;

(2)、同级代码(缩进相同)的 注释(行注释/块注释)前面,必须有一个空行;

(3)、各个方法/函数 之间有一个空行;

(4)、namespace语句、use语句、clase语句 之间有一个空行;

(5)、return语句

如果 return 语句之前只有一行PHP代码,return 语句之前不需要空行;

如果 return 语句之前有至少二行PHP代码,return 语句之前加一个空行;

(5)、if,while,switch,for,foreach、try 等代码块之间 以及 与其他代码之间有一个空行;

 


 

【参考示例 汇总】

参考1:

1

2

3

4

5

6

7

8

namespace Lib\Databaes;

class Mysql extends ParentClass implements \PDO, \DB { // 写一行

public getInfo($name, $age, $gender = 1) { // 参数之间有一个空格。默认参数的“=”左右各有一个空格,) 与 { 之间有一个空格

}

}

参考2:

1

2

3

4

5

6

7

8

9

10

11

namespace Vendor\Package;

abstract class ClassName {

protected static $foo; // static放后面

abstract protected function zim(); // abstract放前面

final public static function bar() { // final放前面,static放最后。

// 方法主体部分

}

}

参考3:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

namespace library\Model;

use library\Helper\ImageHelper;

use library\Logic\UserMainLogic;

/**

* 用户表 数据模型

*

* @package library\Model

*/

class UserMainModel extends BasicModel {

/**

* 获得用户统计信息

*

* @param int $userId 用户ID

* @return array

*/

public function getUserCard($userId) {

$userId = intval($userId);

return UserMainLogic::instance()->getUserCard($userId);

    }

 

    /**

     * 根据Id 获取用户信息

     *

     * @param int    $userId 用户Id

     * @param string $field  显示字段

     * @return array

     */

    public function getByUserId($userId = 0, $field = '*') {

        if (empty($userId)) {

            return array();

        }

 

        $where = array('id' => $userId);

        $info = $this->field($field)->where($where)->find();

 

        if (isset($info['image']) && isset($info['sex'])) {

            $info['image'] = ImageHelper::GetImageUrl($info['image'], $info['sex']);

        }

 

        return $info;

    }

}

参考4:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

$serv = new swoole_server("127.0.0.1", 9502);

 

// sets server configuration, we set task_worker_num config greater than 0 to enable task workers support

$serv->set(array('task_worker_num' => 4));

 

// attach handler for receive event, which have explained above.

$serv->on('receive', function($serv, $fd, $from_id, $data) {

    // we dispath a task to task workers by invoke the task() method of $serv

    // this method returns a task id as the identity of ths task

    $task_id = $serv->task($data);

    echo "Dispath AsyncTask: id=$task_id\n";

});

 

// attach handler for task event, the handler will be executed in task workers.

$serv->on('task', function ($serv, $task_id, $from_id, $data) {

    // handle the task, do what you want with $data

    echo "New AsyncTask[id=$task_id]".PHP_EOL;

 

    // after the task task is handled, we return the results to caller worker.

    $serv->finish("$data -> OK");

});

 

// attach handler for finish event, the handler will be executed in server workers, the same worker dispatched this task before.

$serv->on('finish', function ($serv, $task_id, $data) {

    echo "AsyncTask[$task_id] Finish: $data".PHP_EOL;

});

 

$serv->start();

 

 

总结:所有左花括号 { 都不换行,并且 { 紧挨着的下方,一定不是空行!

 

上面的 代码样式规范,参考了 Java、JavaScript、Objective-C、Go 等开发语言的规范!

Java语言对中国程序员影响太深,大部分人还是习惯把 左花括号 { 不换行!

书写原则:做到 代码紧凑 而又不失 小模块化 !

  

PSR-4 规范

PSR-4规范是刚出没多久的一条新的规范,它也是规范 自动加载(autoload)的,是对PSR-0的修改,属于补充规范,

我简单说下,主要是以下几点: 

  1. 废除了PSR-0中_就是目录分割符的写法,_下划线在完全限定类名中是没有特殊含义了。 

  2. 类文件名要以 .php 结尾。 

  3. 类名必须要和对应的文件名要一模一样,大小写也要一模一样。

 

 

参考:

代码风格研究:左花括号 是否换行???

PHP中PSR-[0-4]代码规范

【补充】数组 的书写格式

只有一个键值对时,就写成一行:

1

$where = array('id' => 789);

有多个(二个或二个以上)键值对时,就换行:

1

2

3

4

$where = array(

    'id' => 789,

    'user_name' => 'phpgo'

);

相关推荐:

ThinkPHP 3.2.3 分页代码样式分享

PHP代码样式

php关于编码规范的文档(收藏)

以上是PHP代码样式风格规范分享的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1677
14
CakePHP 教程
1431
52
Laravel 教程
1334
25
PHP教程
1280
29
C# 教程
1257
24
继续使用PHP:耐力的原因 继续使用PHP:耐力的原因 Apr 19, 2025 am 12:23 AM

PHP仍然流行的原因是其易用性、灵活性和强大的生态系统。1)易用性和简单语法使其成为初学者的首选。2)与web开发紧密结合,处理HTTP请求和数据库交互出色。3)庞大的生态系统提供了丰富的工具和库。4)活跃的社区和开源性质使其适应新需求和技术趋势。

如果session_start()被多次调用会发生什么? 如果session_start()被多次调用会发生什么? Apr 25, 2025 am 12:06 AM

多次调用session_start()会导致警告信息和可能的数据覆盖。1)PHP会发出警告,提示session已启动。2)可能导致session数据意外覆盖。3)使用session_status()检查session状态,避免重复调用。

IIS和PHP的兼容性:深度潜水 IIS和PHP的兼容性:深度潜水 Apr 22, 2025 am 12:01 AM

IIS和PHP可以兼容,通过FastCGI实现。1.IIS通过配置文件将.php文件请求转发给FastCGI模块。2.FastCGI模块启动PHP进程处理请求,提高性能和稳定性。3.实际应用中需注意配置细节、错误调试和性能优化。

session_start()函数的意义是什么? session_start()函数的意义是什么? May 03, 2025 am 12:18 AM

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。

作曲家:通过AI的帮助开发PHP 作曲家:通过AI的帮助开发PHP Apr 29, 2025 am 12:27 AM

AI可以帮助优化Composer的使用,具体方法包括:1.依赖管理优化:AI分析依赖关系,建议最佳版本组合,减少冲突。2.自动化代码生成:AI生成符合最佳实践的composer.json文件。3.代码质量提升:AI检测潜在问题,提供优化建议,提高代码质量。这些方法通过机器学习和自然语言处理技术实现,帮助开发者提高效率和代码质量。

使用Laravel:使用PHP简化Web开发 使用Laravel:使用PHP简化Web开发 Apr 19, 2025 am 12:18 AM

Laravel优化Web开发流程的方法包括:1.使用路由系统管理URL结构;2.利用Blade模板引擎简化视图开发;3.通过队列处理耗时任务;4.使用EloquentORM简化数据库操作;5.遵循最佳实践提高代码质量和可维护性。

PHP和IIS:让他们一起工作 PHP和IIS:让他们一起工作 Apr 21, 2025 am 12:06 AM

在IIS上配置和运行PHP需要以下步骤:1)下载并安装PHP,2)配置IIS并添加FastCGI模块,3)创建并设置应用池,4)创建网站并绑定到应用池。通过这些步骤,你可以在Windows服务器上轻松部署PHP应用,并通过配置扩展和优化性能来提升应用的稳定性和效率。

H5:HTML5的关键改进 H5:HTML5的关键改进 Apr 28, 2025 am 12:26 AM

HTML5带来了五个关键改进:1.语义化标签提升了代码清晰度和SEO效果;2.多媒体支持简化了视频和音频嵌入;3.表单增强简化了验证;4.离线与本地存储提高了用户体验;5.画布与图形功能增强了网页的可视化效果。

See all articles