当前位置:首页 > CN2资讯 > 正文内容

PHP书写规范 PHP Coding Standardphp spreadsheet

14小时前CN2资讯

通用原则:

1、语义化

看到名字,就知道意思。

2、通用前缀

is表示是否、get表示读、set表示写。is后面优先跟形容词,而不是名词,比如是否多语言文字,应使用is_multilingual,而不是is_multilanguage。

3、单数与复数

参考js的函数命名规则:getElementById、getElementsByTagName、getElementsByName。

例如:

取我的多个好友的名字,应使用getFriendsName,而不是getFriendNames或者getFriendName

取一个用户,是getUser

取多个用户,是getUsers

4、冗余后缀

尽量不使用data、list、info后缀。

比如,js的命名就很注意,使用getElementsByTagName而不是getElementsInfoByTagName。

应该使用getFriends或者getFriendsUserId,而不是getFriendsList;应该使用getUser,而不使用getUserInfo或者getUserData。

不过有时候很难避免,比如有2个函数,分别是取用户基本信息,和取用户详细信息。

取用户基本信息:昵称、头像URI,函数名getUserBasic还是getUserBasicInfo?函数名以形容词结尾感觉不合适,待讨论。

取用户详细信息:昵称、头像URI、签名、生日,函数名getUser没问题。

5、含义模糊的类名、文件名、目录名

每 当使用common、util、functions、class、object、basic作为文件名时要慎重,由于这些词太通用,发展下去里面东西可 能越来越多,变成垃圾箱。要给这些起一个准确的名字,比如要做字符串处理的类,可以叫StringLib.php,放在lib目录里。

6、lib、plugin与addon的区别

有些类、函数算做lib、plugin还是addon。待讨论。

类名:

大写字母开头,驼峰命名。一般使用名词,比如配置解析类ConfigParser,而不是ParseConfig。

与Java、C++一致。

例如:class UserModel

类的文件名:

与类名相同。这与php autoload有关,为了autoload,类名总要很长,待讨论。

与Java一致。

例如:class UserModel的文件名为UserModel.php

非类文件名:

全小写,下划线分隔,不得使用空格。比如get_user.php。

目录名:

全小写,下划线分隔,不得使用空格。比如model、www。

函数名:

小写字母开头,驼峰命名,例如:function addBlog()。

与Java、C++一致。

函数表示功能,即动作,所以动词优先,例如使用editBlog,而不用blogEdit。

PHP内置函数由于历史原因,有多种风格,do_something,something_do,dosomething,比较新的函数用了doSomething,才与目前主流语言保持一致。

比如:paser_str、json_encode、substr、fetchAll。

历史原因可能无法改变,但我们能保证新的代码是严谨的,不要让自己成为历史原因。

类中的函数:

两个函数中间空一行。如果有时间的话,各个函数按英文字母排序,免得太混乱。

例如:

class BlogModel { public function addBlog() { } public function updateBlog() { } }

文件注释:

注释紧跟<?php下一行。注明作者。@version暂不需要写,因为svn提供了版本管理。

格式按照PHPdoc的要求:

http://manual.phpdoc.org/HTMLframesConverter/default/phpDocumentor/tutorial_tags.author.pkg.html

<?php /** * blog的各种业务:添加、更新 * @author sink * */ class BlogModel { } ?>


API注释:

一定要写输入参数,和输出格式。写清楚正确时输出什么,错误时输出什么。

否则别人无法使用。

函数注释:

一定要写输出格式。写清楚正确时输出什么,错误时输出什么。

如果输入参数比较复杂,包含数组,看参数无法一目了然,则要写输入参数的注释。

文档注释与函数之间不能有空行。

如果函数内部步骤比较复杂,需要写“行内注释”。

例如:

/** * 更新blog * @param int $id blog_id * @param array $data array( "content" => "", //内容 "tags" => "", //标签 "update_time" => "", //更新时间 ) * @return bool */ public function updateBlog($id,$data) { step1 //第一步:asdf step2 //第二步:qwer }

URI:

根据rfc1034国际标准的规定,域名中禁止出现下划线“_”,域名不区分大小写。

比如http://dl_dir./是错误域名。

http://example.com与http://EXAMPLE.COM相同。

所以优先在URI中使用全小写,GET的name小写,但是GET的值除外。

比如

http:///?hl=zh-CN

http:///?hl=zh-cn

URI中非参数的专有名词的缩写是否使用小写,有争议无定论。

比如

http://fedoraproject.org/zh_CN/

http:///zh-cn/

http:///intl/zh-CN/

http://www.microsoft.com/en-us/

语言文字代码是专有名词,ISO规定必须是减号,且建议地区使用大写。

fedora的用法很奇怪,使用了自己制造的zh_CN,而不是zh-CN。而且不建议在URI中使用下划线。

wiki用了小写,google用了大写,微软用了小写。

优先在URI中使用减号“-”,而不是下划线,GET的name除外。

比如

http://example.com/1-2-2

http://example.com/?user_id=123

如果希望用户手动输入URI,则不要区分大小写,且优先使用小写,因为用户输入更方便。

实际情况是:用户一般是手动输入域名,而不手动输入URI,因为URI很长。在这种情况下,URI小写是否有意义,如果使用 http://example.com/?userId=123,变量名就可以使用驼峰$userId = $_GET['userId'],就能够和Java、C++保持一致,这样数据库也要驼峰命名。待讨论。

变量:

全小写,下划线分隔,例如:$user_id。

与Java、C++不一致。待讨论。

类的成员变量、函数的形参、类实例化成一个对象,都遵守变量的命名规则。

原因:URI、数据库有小写惯例,从$_GET、$_POST中获得参数入库,所以用小写。

PHP内置变量$_GET、$_POST使用下划线开头,全大写。自定义的变量无论多么重要,都不要使用下划线开头,以免将来与内置变量冲突。

比如:不要使用$_PUT、$_DELETE。

常量:

全大写,下划线分隔。例如:const MEMCACHE_TTL = 600;

PHP短标签:

使用,不使用短标签。因为与xml冲突,且不利于部署。

类大括号换行:

可以采用大括号单独占一行,也可以大括号与别的放在一行,有争议无定论,待讨论。

class UserModel { }

支持换行者:

http://www.php.net/manual/zh/language.oop5.basic.php

http://pear.php.net/manual/en/standards.classdef.php

函数大括号换行:

有争议无定论,待讨论。

function getUser() { }

支持换行者:

http://www.php.net/manual/zh/language.oop5.basic.php

http://pear.php.net/manual/en/standards.funcdef.php

if大括号换行:

有争议无定论,待讨论。

例如:

if(!emptyempty($name)) { }

或者

if(!emptyempty($name)){ }

支持换行者:

http://www.possibility.com/Cpp/CppCodingStandard.html#brace

支持同行者:

http://www.php.net/manual/zh/language.oop5.basic.php

http://pear.php.net/manual/en/standards.control.php

switch大括号换行:

switch (...) { case 1: ... break; default: }

支持换行者:

http://www.possibility.com/Cpp/CppCodingStandard.html#switch

数组小括号换行

有争议无定论,待讨论。

$user = array( "id" => "123", "name" => "user1", "email" => "[email protected]", )

支持同行者:

http://pear.php.net/manual/en/standards.arrays.php

数组内部换行:

2维及以上数组的数组内部换行。

$user = array( 'id' => '123', 'name' => 'user1', 'email' => '[email protected]', );

1维数组内部不换行?待讨论。


$users_id = array('23','12','24');

数组最后的逗号:

数组每一行最后要有逗号,这样方便以后添加。不过前端JSON最后不能有逗号,否则有的浏览器不支持,待讨论。

比如

$user = array( 'id' => '123', 'name' => 'user1', //正确 ); $user = array( 'id' => '123', 'name' => 'user1' //错误 );

单引号与双引号:

优先使用单引号,当需要转义时使用双引号。这与JSON不同,JSON全是双引号,待讨论。

比如:

echo 'name is:' . $name . '.' . "\n"; $user = array( 'id' => '123', );

条件判断的大括号:

必须有大括号,即使只有一行。

正确:

if(!emptyempty($name)) { doSomething(); }

错误:

if(!emptyempty($name)) doSomething();

回车换行:

使用换行LF(\n,0a,Unix风格)。不使用CR+LF(Windows风格)。

参考:http:///zh-cn/%E6%8F%9B%E8%A1%8C

eclipse——》workspace——》New text file line delimiter——》Other:Unix

编码:

使用UTF-8 no BOM。不得使用Windows记事本进行保存,因为记事本是UTF-8 BOM CR+LF。

eclipse——》workspace——》Text file encoding——》Other:UTF-8

缩进:

使用4个空格进行缩进,也可以采用tab进行缩进。有争议无定论,待讨论。

支持4个空格者:

http://www.oracle.com/technetwork/java/codeconventions-136091.html#262

支持2个空格者:

http:///svn/trunk/cppguide.xml#Spaces_vs._Tabs

支持3、4或8个空格者:

http://www.possibility.com/Cpp/CppCodingStandard.html#indent

要保证缩进正确,如果使用4个空格,一定不要出现5个空格或者11个空格。

eclipse——》General——》Editor——》Text Editors——》show whitespace characters

vim ~/.vimrc

set expandtab

set softtabstop=4

set shiftwidth=4

HTTP协议缓存

文章使用Last Modified表示最后修改时间,不禁止缓存。

header('Last Modified:Sat, 30 Oct 2010 13:21:21 GMT');

需要用户登录的页面,禁止缓存。
header('Cache-Control:max-age=0'); 
header('Cache-Control:private');

HTTP协议编码与mime:

web输出一定要声明编码与mime。charset与分号之间要有一个空格。小写utf-8还是大写UTF-8,尚未找到文档,待调研。

比如
header('Content-Type:application/json; charset=UTF-8'); 
header('Content-Type:application/xml; charset=UTF-8'); 
header('Content-Type:application/xhtml+xml; charset=UTF-8'); 
header('Content-Type:text/plain; charset=UTF-8'); 
header('Content-Type:text/html; charset=UTF-8');

专有名词大小写:

在类、函数、文件名、目录名等各种地方,不特殊对待专有名词,不采用全大写。

原因:专有名词难以界定,比如HTML、CSS、CRUD。而且全大写导致与驼峰冲突,比如页面助手类,全大写是HTMLHelper,不如HtmlHelper。

支持不特殊处理:

HTML是专有名词,但mime中就使用Content-Type:text/html,而不是text/HTML。

例子:

采用UserDb.php,而不是UserDB.php。

    你可能想看:

    扫描二维码推送至手机访问。

    版权声明:本文由皇冠云发布,如需转载请注明出处。

    本文链接:https://www.idchg.com/info/26045.html

    分享给朋友:

    “PHP书写规范 PHP Coding Standardphp spreadsheet” 的相关文章

    中国电信CN2线路接线指南:快速搭建高效网络连接

    在当今信息化时代,网络已经成为企业运营和日常生活不可或缺的一部分。而对于追求高品质网络体验的用户来说,中国电信的CN2线路无疑是一个excellent选择。CN2线路以其高带宽、低延迟和高稳定性著称,广泛应用于企业、游戏服务器、视频传输等多个领域。对于许多用户来说,CN2线路的接线过程可能会显得复杂...

    ZGOVPS高性能VPS主机:提升网站速度与跨境访问体验的最佳选择

    ZGOVPS的背景与市场定位 ZGOVPS是一家专注于提供高性能VPS主机服务的商家,凭借其出色的性价比和良好的用户口碑,迅速在站长圈中站稳了脚跟。它的市场定位非常明确,主要服务于那些对网络性能有较高要求的用户,尤其是需要跨境访问的网站。对于国内用户来说,访问国外机房时常常会遇到线路问题,导致访问速...

    如何通过命令行安装DSM软件:步骤与技巧教学

    什么是DSM? DSM,即DiskStation Manager,是为Synology NAS设备设计的一款操作系统。它不仅提供了存储管理的基本功能,还有很多高级应用,像文件共享、备份解决方案以及多媒体服务等。可以说,DSM就像一种灵活的操作平台,让用户能够通过直观的界面轻松管理他们的数据和设备。...

    性价比VPS:高效节约的虚拟专用服务器选择指南

    在讨论性价比VPS之前,我觉得先弄清楚什么是性价比VPS特别重要。简而言之,性价比VPS是指在一定的价格范围内,提供较高的性能和稳定性的虚拟专用服务器。这类服务在近几年变得越来越受欢迎,特别是对于那些预算有限但又希望拥有高质量主机服务的人来说,性价比高的VPS就像是一道光,照亮了他们的选择之路。 性...

    DMIT VPS怎么样?性能与价格的全面评测

    在选择VPS的时候,性能绝对是一个关键因素。对于DMIT VPS,我从多个层面来进行评测,特别是它的处理器和存储配置。DMIT采用的Intel至强处理器,真的是一大亮点。这种处理器在处理高负载任务时表现十分优越,其稳定性和速度都让人印象深刻。而且,配合全SSD RAID存储方案,数据的读写速度得到了...

    机房迁移全攻略:确保系统安全与顺利过渡的最佳实践

    机房迁移是一个涉及将数据中心内各种设备从一个地点转移到另一个地点的复杂过程。具体包括服务器、存储设备以及网络设备等。这样的迁移通常不仅仅是物理搬运,还涉及到设备的断电、拆卸、运输、重新安装与最后的测试,确保系统在新环境中能够正常运行。对于企业而言,这一过程对运营的影响极小,数据的安全性必须得到保障,...