`
myoldman
  • 浏览: 84853 次
  • 性别: Icon_minigender_1
  • 来自: 福建福州
最近访客 更多访客>>
社区版块
存档分类
最新评论

Zend Framework编码规则

    博客分类:
  • php
阅读更多
B.2. PHP File 文件格式
B.2.1.  常规
对于只包含有 PHP 代码的文件,结束标志("?>")是不允许存在的,PHP自身不需要("?>"), 这样做, 可以防止它的末尾的被意外地注入空白并显示输出。

重要: 由 __HALT_COMPILER() 允许的任意的二进制代码的内容被 Zend Framework PHP 文件或由它们产生的文件禁止。这个功能的使用只对特殊的安装脚本开放。

B.2.2.  缩进
使用四个空格的缩进,而不使用制表符 TAB 。

B.2.3.  行的最大长度
一行 80 字符以内是比较合适, 长点也可以, 但最多为 120 个字符。

B.2.4.  行结束标志
行结束标志只能是标准的 unix 文本文件的换行,换行符在文件中表示为 10,或16进制的 0x0A。

不要使用 Macintosh 电脑的回车如(0x0D)。

不要使用 Windows 电脑的回车换行组合如(0x0D,0x0A)。

B.3.  命名约定
B.3.1.  类
Zend Framework 的类命名总是对应于其所属文件的目录结构的,Zend Framework 的根目录是 “Zend/”,所有的类在其下按等级存放。

类名只允许有字母数字字符,但不鼓励使用数字。下划线只允许做路径分隔符,例如 Zend/Db/Table.php 文件里对应的类名称是 Zend_Db_Table。

如果类名包含多个单词,每个单词的第一个字母必须大写,连续的大写是不允许的,例如 “Zend_PDF” 是不允许的,而 "Zend_Pdf" 是可接受的。

由 Zend 或其参与 Zend Framework 项目的伙伴公司发行的类必须以 "Zend_" 开头并且必须按等级放在 "Zend/"目录下。

可接受的类名的例子:


Zend_DbZend_ViewZend_View_Helper
重要: 最终用户写的代码,不要以 "Zend_" 开头。

B.3.2.  接口
接口类也必须遵循同样的约定(如上所述),但必须以 "Interface" 结尾,比如这些例子:


Zend_Log_Adapter_InterfaceZend_Controller_Dispatcher_Interface

B.3.3.  文件名
对于其它文件,只有字母数字字符、下划线和短横线("-")可用,空格是不允许的。

包含任何 PHP 代码的任何文件必须以 ".php" 扩展名结尾。这些例子给出可接受的文件名,它们包含的类名都在上述章节的例子中:


Zend/Db.phpZend/Controller/Front.phpZend/View/Helper/FormRadio.php
文件名必须遵循上述的对应类名的规则。

B.3.4.  函数和方法
函数名只包含字母数字字符,但不鼓励使用数字,下划线是不允许的。

函数名总是以小写开头,当函数名包含多个单词,每个子的首字母必须大写,这就是所谓的 “驼峰” 格式。

我们鼓励使用冗长的名字,这样容易理解代码。

这些是可接受的函数名的例子:


filterInput()getElementById()widgetFactory()

对于面向对象编程,对象的访问器总是以 "get" 或 "set" 为前缀。当使用设计模式如 单态模式(singleton)或工厂模式(factory),方法的名字应当包含模式的名字,这样容易从名字识别设计模式。

在对象中的方法,声明为 "private" 或 "protected" 的, 名称的首字符必须是一个单个的下划线,这是唯一的下划线在方法名字中的用法。声明为 "public" 的从不以下划线开头。

全局函数 ("floating functions") 允许但不鼓励,建议把这类函数封装到静态类里。

B.3.5.  变量
变量只包含数字字母字符,不鼓励使用数字,下划线不接受。

声明为 "private" 或 "protected" 的类成员变量名必须以一个单个下划线开头,这是唯一的下划线在变量名中的用法,声明为 "public" 的从不以下划线开头。

象函数名(见上面 3.3 节)一样,变量名总以小写字母开头并遵循“驼峰式”命名约定。

我们鼓励使用冗长的名字,这样容易理解代码。除非在小循环里,不鼓励使用简洁的名字如 "$i" 和 "$n" 。如果一个循环超过 20 行代码,索引的变量名必须有个具有描述意义的名字。

B.3.6.  常量
常量包含数字字母字符和下划线,数字允许作为常量名。

常量名的所有字母必须大写。

为加强可读性,常量中的单词必须以下划线分隔,例如可以这样 EMBED_SUPPRESS_EMBED_EXCEPTION 但不许这样 EMBED_SUPPRESSEMBEDEXCEPTION。

常量必须通过 "const" 定义为类的成员,不鼓励使用 "define" 定义的全局常量。

B.4.  编码风格
B.4.1. PHP 代码划分(Demarcation)
PHP 代码总是用完整的标准的 PHP 标签定界:


<?php?>


短标签( )是不允许的,只包含 PHP 代码的文件,不要结束标签 (参见 第 B.2.1 节 “ 常规 ”)。

B.4.2.  字符串
B.4.2.1.  字符串文字
当字符串是文字(不包含变量),用单引号( apostrophe )来括起来:


$a = 'Example String';

B.4.2.2.  包含单引号(')的字符串文字
当文字字符串包含单引号(apostrophe )就用双引号括起来,特别在 SQL 语句中:


$sql = "SELECT `id`, `name` from `people` WHERE `name`='Fred' OR `name`='Susan'";
在转义单引号时,上述语法是首选的。

B.4.2.3.  变量替换
变量替换有下面两种形式:


$greeting = "Hello $name, welcome back!";$greeting = "Hello {$name}, welcome back!";

为保持一致,这个形式不允许:


$greeting = "Hello ${name}, welcome back!";

B.4.2.4.  字符串连接
字符串用 "." 操作符连接,在它的前后加上空格以提高可读性:


$company = 'Zend' . ' ' . 'Technologies';

当用 "." 操作符连接字符串,代码可以分成多个行,也是为提高可读性。在这些例子中,每个连续的行应当由 whitespace 来填补,例如 "." 和 "=" 对齐:


$sql = "SELECT `id`, `name` FROM `people` "     . "WHERE `name` = 'Susan' "     . "ORDER BY `name` ASC ";

B.4.3.  数组
B.4.3.1.  数字索引数组 Numerically Indexed Arrays
索引不能为负数

建议数组索引从 0 开始。

当用 array 声明有索引的数组,在每个逗号的后面价格空格以提高可读性:


$sampleArray = array(1, 2, 3, 'Zend', 'Studio');

也可以用 "array" 声明多行有索引的数组,在每个连续行的开头要用空格填补对齐:


$sampleArray = array(1, 2, 3, 'Zend', 'Studio',                     $a, $b, $c,                     56.44, $d, 500);

B.4.3.2.  关联数组
当用 声明关联数组,array 我们鼓励把代码分成多行,在每个连续行的开头用空格填补来对齐键和值:


$sampleArray = array('firstKey'  => 'firstValue',                     'secondKey' => 'secondValue');

B.4.4.  类
B.4.4.1.  类的声明
用下面的约定来命名类。

花括号总是从类名下一行开始。

每个类必须有一个符合 PHPDocumentor 标准的文档块。

四个空格的缩进。

每个 PHP 文件中只有一个类。

放另外的代码到类里允许但不鼓励。在这些文件中,用两行空格来分隔类和其它代码。

这是个可接受的类的例子:


/** * Documentation Block Here */class SampleClass{    // entire content of class    // must be indented four spaces}

B.4.4.2.  类成员变量
必须用下面的变量名约定来命名类成员变量。

变量的声明必须在类的顶部,要先于方法的声明。

不允许使用 var (因为 ZF 是基于 PHP 5 的 ),要用 private、 protected 或 public。直接访问变量允许但不鼓励,最好使用访问器 (set/get)。

B.4.5.  函数和方法
B.4.5.1.  函数和方方声明
必须用下面的变量名约定来命名函数。

在类中的函数必须用 private、 protected 或 public 声明它们的可见性。

象类一样,花括号从函数名的下一行开始,函数名和括参数的圆括号中间没有空格。

强烈反对使用全局函数。

可接受的在类中的函数声明的例子:


/** * Documentation Block Here */class Foo{    /**     * Documentation Block Here     */    public function bar()    {        // entire content of function        // must be indented four spaces    }}

注: 传址(Pass-by-reference)只在函数声明中允许:


/** * Documentation Block Here */class Foo{    /**     * Documentation Block Here     */    public function bar(&$baz)    {}}

传址在调用时是禁止的。

返回值不能在圆括号中,这妨碍可读性而且如果将来方法被修改成传址方式,代码会有问题。


/** * Documentation Block Here */class Foo{    /**     * WRONG     */    public function bar()    {        return($this->bar);    }    /**     * RIGHT     */    public function bar()    {        return $this->bar;    }}

B.4.5.2.  函数和方法的用法
函数的参数用逗号和紧接着的空格分开,下面的例子中的函数带有三个参数:


threeArguments(1, 2, 3);

传址方式在调用的时候是禁止的,参见函数的声明一节如何正确使用函数的传址方式。

带有数组参数的函数,函数的调用可包括 "array" 并分成多行来提高可读性,同时,书写数组的标准仍然适用:


threeArguments(array(1, 2, 3), 2, 3);threeArguments(array(1, 2, 3, 'Zend', 'Studio',                     $a, $b, $c,                     56.44, $d, 500), 2, 3);

B.4.6.  控制语句
B.4.6.1. If / Else / Elseif
使用 if and elseif 的控制语句在条件语句的圆括号前后都必须有一个空格。

在圆括号里的条件语句,操作符必须用空格分开,鼓励使用多重圆括号以提高在复杂的条件中划分逻辑组合。

前花括号必须和条件语句在同一行,后花括号单独在最后一行,其中的内容用四个空格缩进。


if ($a != 2) {    $a = 2;}

下面的例子示例 "if" 语句, 包括 "elseif" 或 "else" 的格式约定:


if ($a != 2) {    $a = 2;} else {   $a = 7;}if ($a != 2) {    $a = 2;} elseif ($a == 3) {   $a = 4;} else {   $a = 7;}
在有些情况下, PHP 允许这些语句不用花括号,但在 ZF 代码标准里,它们("if"、 "elseif" 或 "else" 语句)必须使用花括号。

"elseif" 是允许的但强烈不鼓励,我们支持 "else if" 组合。

B.4.6.2. Switch
在 "switch" 结构里的控制语句在条件语句的圆括号前后必须都有一个单个的空格。

"switch" 里的代码必须有四个空格缩进,在"case"里的代码再缩进四个空格。


switch ($numPeople) {    case 1:        break;    case 2:        break;    default:        break;}
switch 语句中必须有 default。

注: 有时候,在 falls through 到下个 case 的 case 语句中不写 break or return 很有用。为了区别于 bug,任何 case 语句中,所有不写 break or return 的地方必须有 "// break intentionally omitted" 这样的注释。

B.4.7.  注释文档
B.4.7.1.  格式
所有文档块 ("docblocks") 必须和 phpDocumentor 格式兼容,phpDocumentor 格式的描述超出了本文档的范围,关于它的详情,参考:http://phpdoc.org/。

所有 Zend Framework 或和它一起工作的源代码必须在每个文件的顶部包含文件级 ("file-level")的 docblock ,在每个类的顶部放置一个 "class-level" 的 docblock。下面是一些例子:

B.4.7.2.  文件
每个包含 PHP 代码的文件必须至少在文件顶部包含这些 phpDocumentor 标签:


/** * 文件的简短描述 * * 文件的详细描述(如果有的话)... ... * * LICENSE: 一些 license 信息 * * @copyright  2005 Zend Technologies * @license    http://www.zend.com/license/3_0.txt   PHP License 3.0 * @version    $Id:$ * @link       http://dev.zend.com/package/PackageName * @since      File available since Release 1.2.0*/

B.4.7.3.  类
每个类必须至少包含这些 phpDocumentor 标签:


/** * 类的简述 * * 类的详细描述 (如果有的话)... ... * * @copyright  2005 Zend Technologies * @license    http://www.zend.com/license/3_0.txt   PHP License 3.0 * @version    Release: @package_version@ * @link       http://dev.zend.com/package/PackageName * @since      Class available since Release 1.2.0 * @deprecated Class deprecated in Release 2.0.0 */

B.4.7.4.  函数
每个函数,包括对象方法,必须有最少包含下列内容的文档块(docblock):

函数的描述

所有参数

所有可能的返回值


因为访问级已经通过 "public"、 "private" 或 "protected" 声明, 不需要使用 "@access"。

如果函数/方法抛出一个异常,使用 @throws:


@throws exceptionclass [description]

分享到:
评论

相关推荐

    zend framework 1.7.5 使用基本例子

    **Zend Framework 1.7.5 基本使用教程** Zend Framework 是一个开源的、基于组件的PHP框架,用于构建可扩展、高性能的Web应用。版本1.7.5是该框架的一个重要里程碑,提供了丰富的功能和改进,旨在提高开发效率。在...

    Zend Framework API documentation

    Zend Framework API 文档是一份详尽的资源,专为开发者提供关于 Zend Framework 的技术信息和使用指南。这个框架是用 PHP 开发的,旨在帮助构建高质量、可维护的 Web 应用程序。其 API(应用程序编程接口)文档是...

    诗意的边缘:PHP顶级框架Zend Framework开发实战-代码

    Zend Framework 强调安全性,包括 CSRF 防御、XSS 防护、输入过滤和输出编码等。Zend_Auth 和 Zend_Acl 可用于实现身份验证和访问控制。 **9. 错误处理与日志记录** Zend_Exception 和 Zend_Log 分别提供了异常...

    ZendFramework中文文档

    1. Introduction to Zend Framework 1.1. 概述 1.2. 安装 2. Zend_Acl 2.1. 简介 2.1.1. 关于资源(Resource) 2.1.2. 关于角色(Role) 2.1.3. 创建访问控制列表(ACL) 2.1.4. 注册角色(Role) 2.1.5. 定义访问...

    Zend Framework 中英文手册 CHM 格式最新版

    4. **表单处理**:Zend_Form组件允许开发者创建和验证表单,包括元素、装饰器和验证规则,确保用户输入数据的安全性和准确性。 5. **Ajax和Web服务**:通过Zend_XmlRpc和Zend_Rest,可以快速构建XML-RPC和RESTful ...

    zend framework编码规范

    ### ZEND Framework 编码规范详解 #### A.1. 总论 **范围与目的** 在软件开发领域,特别是基于 ZEND Framework 的项目中,统一且规范化的编码标准至关重要。良好的编码标准不仅能提升代码质量,还能增强项目的可...

    zend framework2 demo

    **标题:“zend framework2 demo”** **描述:**“这个实例是基于 Zend Framework2 的一个演示项目,可以直接配置为Web站点进行运行。源代码来源于官方,更多关于此实例的详细信息建议查阅 Zend Framework2 官方...

    Zend Framework中文手册

    包括输入过滤(`Zend_Filter` 和 `Zend_Validate`)、输出编码(`Zend_Escape`)、认证(`Zend_Auth`)和授权(`Zend_Acl`)等安全功能,为Web应用程序提供了全面的安全保障。 11. **文件上传和下载** `Zend_File...

    zendframework 留言板 经典

    在“zendframework 留言板 经典”项目中,我们可以深入探讨如何利用Zend Framework构建一个基础的留言板系统。 1. **.htaccess 文件**:这是一个Apache服务器的配置文件,用于设置URL重写规则。在留言板应用中,它...

    Manning Zend Framework in Action

    ### Manning Zend Framework in Action #### 一、介绍 **标题**:“Manning Zend Framework in Action” **描述**:“Manning Zend Framework in Action” 本部分主要介绍《Manning Zend Framework in Action》...

    ZendFramework-1.0.2.zip

    Zend Framework 1.0.2的发布,还包含了对安全性的增强,例如输入过滤(Zend_Filter)、输出编码(Zend_Escape)以及防止SQL注入和XSS攻击的机制,保障了应用的安全性。 此外,Zend Framework 1.0.2还提供了强大的...

    PHP沉思录之四 Zend Framework.pdf

    12. **安全特性**:包括输入过滤(Zend_Filter)、输出编码(Zend_Escape)以及防止SQL注入和跨站脚本攻击的策略。 13. **缓存机制**:通过Zend_Cache,可以实现数据和页面的缓存,提高应用性能。 14. **持续集成...

    zendframework+smarty+ajax经典实例

    在《zendframework+smarty+ajax经典实例》中,Ajax的应用可能体现在chapter-09.zip和chapter-11.zip,涵盖了如何在Smarty模板中嵌入Ajax代码,以及如何与Zend Framework的控制器交互,实现实时数据交换。 此外,...

    Zend Framework例子

    ** Zend Framework 概述** Zend Framework 是一个基于 Model-View-Controller (MVC) 设计模式的开源 PHP 框架,它旨在提供高度可扩展性和灵活性,用于构建高质量的 Web 应用程序。框架的核心组件包括:路由、控制器...

    Zend Framework2的程序员参考指南

    **一、Zend Framework 2 知识点** Zend Framework 2 (ZF2) 是一个基于 PHP 5.3 以上的开源框架,专为构建 Web 应用程序和服务而设计。它采用100%面向对象的编码风格,充分利用了 PHP 5.3 引入的新特性,如命名空间...

    Zend Framework动作助手Url用法详解

    值得注意的是,在生成URL时,Zend Framework会遵循默认路由(default route)的规则,除非特别指定了路由名称。默认路由通常包含一个模块名称、控制器名称和动作名称。此外,任何额外的参数都会被添加到URL的查询...

    Zend Framework自定义Helper类相关注意事项总结

    在Zend Framework中,自定义Helper类是为了扩展视图层的功能,使其能够处理特定...遵循以上规则,开发者可以有效地创建和使用自定义Helper类来增强Zend Framework应用程序的视图层功能,提高代码的可重用性和可维护性。

    Zend Framework教程之路由功能Zend_Controller_Router详解

    总结来说,`Zend_Controller_Router`是Zend Framework的核心组件之一,它使得开发者能够根据需要定义和管理复杂的路由规则,从而提高应用程序的灵活性和可维护性。理解和掌握这一组件的用法对于构建高效、可扩展的...

    Array of country list in PHP with Zend Framework

    2. Zend Framework是一个使用PHP语言开发的开源框架,它基于面向对象的设计原则和一些设计模式。 3. Zend_Locale类属于Zend Framework,用于处理与地区设置有关的数据,如货币、日期、数字格式及本文中的国家名称等...

Global site tag (gtag.js) - Google Analytics