PHP编码规范实例
<?php | |
/** | |
* 符合psr-1,2的编程实例 | |
* | |
* @author 作者 描述 | |
*/ | |
namespace Standard; // 顶部命名空间 | |
// 空一行 | |
use Test\TestClass;//use引入类 | |
/** | |
* 类描述 | |
* | |
* 类名必须大写开头驼峰. | |
*/ | |
abstract class StandardExample // {}必须换行 | |
{ | |
/** | |
* 常量描述. | |
* | |
* @var string | |
*/ | |
const THIS_IS_A_CONST = ''; // 常量全部大写下划线分割 | |
/** | |
* 属性描述. | |
* | |
* @var string | |
*/ | |
public $nameTest = ''; // 属性名称建议开头小写驼峰 | |
// 成员属性必须添加public(不能省略), private, protected修饰符 | |
/** | |
* 属性描述. | |
* | |
* @var string | |
*/ | |
private $_privateNameTest = ''; // 类私有成员属性,【个人建议】下划线小写开头驼峰 | |
/** | |
* 构造函数. | |
* | |
* 构造函数描述 | |
* | |
* @param string $value 形参名称/描述 | |
*/ | |
public function __construct($value = '')// 成员方法必须添加public(不能省略), private, protected修饰符 | |
{// {}必须换行 | |
$this->nameTest = new TestClass(); | |
// 链式操作 | |
$this->nameTest->functionOne() | |
->functionTwo() | |
->functionThree(); | |
// 一段代码逻辑执行完毕 换行 | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
* 返回值类型:string,array,object,mixed(多种,不确定的),void(无返回值) | |
*/ | |
public function testFunction($value = '')// 成员方法必须小写开头驼峰 | |
{ | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
private function _privateTestFunction($value = '')// 私有成员方法【个人建议】下划线小写开头驼峰 | |
{ | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
public static function staticFunction($value = '')// static位于修饰符之后 | |
{ | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
abstract public function abstractFunction($value = ''); // abstract位于修饰符之前 | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
final public function finalFunction($value = '')// final位于修饰符之前 | |
{ | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $valueOne 形参名称/描述 | |
* @param string $valueTwo 形参名称/描述 | |
* @param string $valueThree 形参名称/描述 | |
* @param string $valueFour 形参名称/描述 | |
* @param string $valueFive 形参名称/描述 | |
* @param string $valueSix 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
public function tooLangFunction( | |
$valueOne = '', // 变量命名可小写开头驼峰或者下划线命名,个人那习惯,据说下划线可读性好 | |
$valueTwo = '', | |
$valueThree = '', | |
$valueFour = '', | |
$valueFive = '', | |
$valueSix = '')// 参数过多换行 | |
{ | |
if ($valueOne === $valueTwo) {// 控制结构=>后加空格,同{一行,(右边和)左边不加空格 | |
// code... | |
} | |
switch ($valueThree) { | |
case 'value': | |
// code... | |
break; | |
default: | |
// code... | |
break; | |
} | |
do { | |
// code... | |
} while ($valueFour <= 10); | |
while ($valueFive <= 10) { | |
// code... | |
} | |
for ($i = 0; $i < $valueSix; $i++) { | |
// code... | |
} | |
} | |
} |
PHP编码规范实例的更多相关文章
- Objective-C开发编码规范【转载】
概要 Objective-C是一门面向对象的动态编程语言,主要用于编写iOS和Mac应用程序.关于Objective-C的编码规范,苹果和谷歌都已经有很好的总结: Apple Coding Guide ...
- 【转】JavaScript 风格指南/编码规范(Airbnb公司版)
原文转自:http://blog.jobbole.com/79484/ Airbnb 是一家位于美国旧金山的公司,本文是其内部的 JavaScript 风格指南/编码规范,在 Github 上有 11 ...
- 资料推荐--Google Java编码规范
之前已经推荐过Google的Java编码规范英文版了: http://google-styleguide.googlecode.com/svn/trunk/javaguide.html 虽然这篇文章的 ...
- 【转】Airbnb React编码规范
Airbnb的编码规范是在业界非常流行的一套规范,而且它一直都在进化,推出最新技术的规范 原文:https://zhuanlan.zhihu.com/p/20616464 用更合理的方式书写React ...
- Python + OpenCV2 系列:3 - python 字符串,类,编码规范
首先,强烈推荐<<简明 Python 教程>> Swaroop, C. H. 著 沈洁元 译 其实,这本书里已经把python的最基本的用法,编码等等介绍的很好,这里把我用到的 ...
- Bootstrap编码规范
黄金定律 永远遵循同一套编码规范 -- 可以是这里列出的,也可以是你自己总结的.如果你发现本规范中有任何错误,敬请指正.通过 open an issue on GitHub为本规范添加或贡献内容. 不 ...
- iOS 注释的5要3不要和编码规范的26个方面
注释 代码注释,可以说是比代码本身更重要.这里有一些方法可以确保你写在代码中的注释是友好的: 不要重复阅读者已经知道的内容 能明确说明代码是做什么的注释对我们是没有帮助的. // If the col ...
- [iOS翻译]Cocoa编码规范
简介: 本文整理自Apple文档<Coding Guidelines for Cocoa>.这份文档原意是给Cocoa框架.插件及公共API开发者提供一些编码指导,实质上相当于Ap ...
- 网易前端JavaScript编码规范
在多年开发邮箱webmail过程中,网易邮箱前端团队积累了不少心得体会,我们开发了很多基础js库,实现了大量前端效果组件,开发了成熟的opoa框架以及api组件,在此向大家做一些分享.今天想先和大家聊 ...
随机推荐
- Extjs6中的新特性
Ext JS在Sencha框架中引入了许多新的和令人兴奋的改进.这些变化为基于所有现代浏览器.设备和屏幕尺寸带来了新的功能和可用性. 工具包(ToolKits) Ext JS 6最大的变化就是将Ext ...
- WPF 制作电子相册浏览器
周末的时候,闲着无聊,做了一个电子相册浏览器.比较简单.界面如下: 主要部分代码如下: MainWindow.xaml <local:HeaderedWindow x:Class="P ...
- UIAlertView使用全解
举例: UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"Default Alert View"messa ...
- 微信小程序登录
一. 小程序不支持cookie会话 1. 通过传递与检验3rd_session来保持会话 2. 3rd_session可以执行'`head -n 80 /dev/urandom | tr -dc A- ...
- 解决eclipse报PermGen space异常的问题
开发中遇到Eclipse报错:java.lang.OutOfMemoryError: PermGen space. 网搜到三种解决方法,最终还是第三种方法起了作用.记录日志,备用. 原文地址: htt ...
- Zynq和microblaze的区别
Zynq钩中PS端的外设之后不需要初始化过程,但是如果在microblaze中连接外设之后需要有初始化过程.
- eclipse 如何debug jdk源码(转)
转:http://blog.csdn.net/cherrycheng_/article/details/51004386 原英文地址:http://stackoverflow.com/question ...
- 代码中引用res里的颜色、图片
1.imageButton userImgButton 在代码中设置图片,使用res/Drawable 里的图片 Resources res = getResources(); Bitmap inDr ...
- 中英文混合字符串截取java
//截取字符串长度(中文2个字节,半个中文显示一个) public String subTextString(String str,int len){ if(str.length()<len/2 ...
- 在vhd中安装win7,并建立分差vhd
准备:硬盘分区激活第一个分区; imagex.exe; install.wim; winpe boot pc 1.cmd命令下,创建主vhd (1)diskpart (打开dis ...