php教程 php手册 php编程代码规范学习笔记(适合初学者)

php编程代码规范学习笔记(适合初学者)

May 26, 2016 am 08:20 AM
PHP 코드 사양 PHP 프로그래밍 사양

php编程代码规范我们会从几个方法来介绍,如:命名规范 常用名词 代码重构了,下面我先整理一些规范之后再整理一些笔记,希望文章对各位朋友会带来一些帮助哦。

命名规范

类文件都以.class.php为后缀,使用驼峰法命名,并且首字母大写,例如 Pay.class.php;

类名和目录_文件名一致。例如:类名Zend_Autoloader的目录是Zend/Autoloader.class.php;

函数的命名使用小写字母和下划线的方式。例如:get_client_ip;

方法的命名使用驼峰法,首字母小写或者使用下划线"_",例如listComment(),_getResource(),通常下划线开头的方法属于私有方法;

属性的命名使用驼峰法,首字母小写或者使用下划线"_",如$username,$_instance,通常下划线开头的属性属于私有属性;

常量以大写字母和下划线"_"命名,如"HOME_URL";

常用名词

1>list名词(单数),如listApple,一看我们就知道读取苹果列表,我们没有必要写成getApples或者listApples或readApples——因为get我们规定一般用于读取单个数据,如getApple.listApples不加s我们也知道是取苹果列表(保证尽量缩短变量命名);

2>get名词(单数);

3>名词Total,表示某个东西的总数。如expenseTotal;

4>found:表示某个值是否已经找到;

5>uccess或ok:一项操作是否成功;

6>done:某个工程是否完成;

7>error:是否有错误发生;

8>result:返回的结果

代码重构

1.函数或者方法体内的代码尽量控制在一个屏幕内。

2.类中不使用的方法随机删除。

3.修改别人的类中方法,要签名。

4.在每个模块内写个readme文件(用于比较复杂业务的说明或代码说明)。

5.尽量让每个类做自己的事,每个函数做一件事。

下面补充一些方法

一、文件格式

1. 对于只含有 php 代码的文件,我们将在文件结尾处忽略掉 ?> 。这是为了防止多余的空格或者其它字符影响到代码。

例如如下代码:

2. 缩进应该能够反映出代码的逻辑结果,尽量使用四个空格,禁止使用制表符TAB,因为这样能够保证有跨客户端编程器软件的灵活性。例如:

if (1 == $x) { 

$indented_code = 1; 

if (1 == $new_line) { 

$more_indented_code = 1; 

3. 变量赋值必须保持相等间距和排列。例如:

$variable = 'demo';$var      = 'demo2';

4. 每行代码长度应控制在80个字符以内,最长不超过120个字符。因为 linux 读入文件一般以80列为单位,就是说如果一行代码超过80个字符,那么系统将为此付出额外操作指令。这个虽然看起来是小问题,但是对于追求完美的程序员来说也是值得注意并遵守的规范。

5. 每行结尾不允许有多余的空格。

二、命名约定

1. 类文件都是以.class.php为后缀,且类文件名只允许字母,使用驼峰法命名,并且首字母大写,例如:DbMysql.class.php 。

2. 配置和函数等其他类库文件之外的文件一般是分别以”.inc.php”和".php”为后缀,且文件名命名使用小写字母和下划线的方式,多个单词之间以下 划线分隔,例如config.inc.php , common.php,install_function.php 。

3. 确保文件的命名和调用大小写一致,是由于在类Unix系统上面,对大小写是敏感的。

4. 类名和文件名一致(包括上面说的大小写一致),且类名只允许字母,例如 UserAction类的文件命名是UserAction.class.php, InfoModel类的文件名是InfoModel.class.php 。

5. 控制器类以Action为后缀,例如 UserAction、InfoAction ,模型类以Model为后缀,例如UserModel、InfoModel ,其他类也分别以相应分类为后缀,例如Service 、Widget。

6. 方法名只允许由字母组成,下划线是不允许的,首字母要小写,其后每个单词首字母要大写,即所谓的 ”驼峰法命名" 规则,且越详细越好,应该能够描述清楚该方法的功能,例如switchModel、findPage。

7. 属性的命名只允许由字母组成,下划线是不允许的,首字母要小写,其后每个单词首字母要大写,即所谓的 ”驼峰法命名" 规则,例如tablePrefix、tableName 。

8. 对于对象成员的访问,我们必须始终使用 ”get" 和 ”set" 方法,例如:

class Foo 
{ 
protected $_testObj; 
public function getTestObj() 
{ 
return $this->_testObj; 
} 
public function setTestObj($testObj) 
{ 
$this->testObj = $_testObj; 
} 
}
로그인 후 복사

9. 当类成员方法被声明为 private 时,必须分别以双下划线 __为开头;被声明为 protected 时,必须分别以单下划线 _ 为开头;一般情况下的方法不含下划线,例如:

class Foo 
{ 
private function __example() 
{ 
// ... 
} 
protected function _example() 
{ 
// ... 
} 
public function example() 
{ 
// ... 
} 
}
로그인 후 복사

10. 如果我们需要把一些经常使用的方法定义为全局函数,那么应该把它们以静态 (static)的形式定义在类中,例如:

class Think 
{ 
// ... 
static public function autoload($classname) 
{ 
// ... 
} 
}
로그인 후 복사

11. 被声明为 private的类成员属性必须由双下划线 __ 作为开头;被声明为 protected 的类成员属性必须由下划线 _ 作为开头;而声明为 public 的成员属性则在任何时候都不允许含有下划线。

12. 函数的命名使用小写字母和下划线的方式,且越详细越好,应该能够描述清楚该函数的功能,例如 get_client_ip 。

13. 当方法或函数参数不一定需要被赋值的时候,用 null 来代替 false 作为函数参数的默认值,除非该参数是 boolean 值。

14. 变量只允许由小写字母和下划线组成,且建议用描述性的变量的命名,越详细越好,以至于像 $i 或 $n 等等都是不鼓励使用的.

15. 类中的常量 constant 和全局范围内常量define,只能由大写字母和下划线组成,各个单词之间以下划线分割.

16. boolean 值和 null 值都采用小写.

三、编码风格

1. php 代码必须以完整的形式来定界(),即不要使用php 短标签(),且保证在关闭标签后不要有任何空格.

2. 当一个字符串是纯文本组成的时候(即不含有变量),则必须总是以单引号(')作为定界符。例如:$a = 'Example String';

3. 变量替换中的变量只允许用 $+变量名 的形式,例如:

$greeting = Hello $name, welcome back!;   // 允许 
$greeting = Hello {$name}, welcome back!; // 允许 
$greeting = Hello ${name}, welcome back!; // 不允许
로그인 후 복사

当用点号 . 连接各字符串的时候,字符串与点号间必须用一个空格隔开,且允许把它分割成多行以增强可读性,在这种情况下,点号 . 必须与等于号 = 对齐,例如:

$sql = SELECT `id`, `name`  .  FROM `people`  
  . WHERE `name` = 'Susan'  
  . ORDER BY `name` ASC ;
로그인 후 복사

当用 array 类型符号来构造数组的时候,必须在每个逗号之后加上一个空格来增强可读性,例如:$sampleArray = array(1, 2, 3, 'Think', 'SNS');

4. 当使用 array 类型符声明关联数组的时候,我们鼓励把它分成多个行,只是我们必须同时保证每行的键与值的对齐,以保持美观,例如:

$sampleArray = array( 
'firstKey'  => 'firstValue', 
'secondKey' => 'secondValue' 
);
로그인 후 복사


5. 大括号的开始必须在类名的下一行顶格,例如:

class Think 
{ 
// ... 
}
로그인 후 복사

6. 类中的所有代码都必须用四个空格来进行缩进。

7. 每个 php 文件只允许声明一个类。在类文件里面写其它代码是允许的,但并不鼓励这样做。假如真要附加代码的话,必须用空行来分隔。

8. 任何类变量的声明都必须放在类顶部,先于任何函数的声明。

9. 不允许用 var 符号来声明变量,类成员变量必须以 private,protected 和 public 来声明。其次,把类成员声明为 public 而直接引用虽然是允许的,但通常更好的方法是使用 get 和 set 方法来访问类成员。

10. 方法必须总是用 private,protected 或者 public 来声明其作用域。

11. 静态 static 方法应该声明其作用域,且不应该再被声明为 private 私有,而应该为 protected 或者public ,如果只是不想被子类继承,则应该用 final 声明它们。

12. 函数或方法的初始大括号应该在函数声明的下一行顶格,例如:

function get_client_ip() 
{ 
// …
}
로그인 후 복사
로그인 후 복사

13. 在函数或方法名与参数括号之间不允许出现多余的空格,例如:

function get_client_ip() 
{ 
// …
}
로그인 후 복사
로그인 후 복사

14. 引用只允许定义在函数参数中,实时传递引用是禁止的,例如:

// 引用定义在函数参数-允许的 
function defineRefInMethod(&$a) 
{ 
$a = 'a'; 
}  
defineRefInMethod($b); 
echo $b; // 'a' 
// 实时传递引用-禁止的 
function callTimePassRef($a) 
{ 
$a = 'a'; 
} 
callTimePassRef(&$c); 
echo $c; // 'a'
로그인 후 복사

15. 函数或方法返回值不可以用括号包住,不然会降低可读性,而且假如以后函数修改为返回引用的话,这将会抛出一个异常.

16. 鼓励尽量使用类型提示,特别是在模块设计中,例如:

class Foo 
{ 
public function foo(SomeInterface $object) 
   {  
} 
public function bar(array $options) 
{ 
} 
}
로그인 후 복사

17. 函数和方法参数必须用逗号+空格来分隔。

18. 对于参数为数组的函数,参数中的数组应该分成多行以增强可读性,例如:

threeArguments(array(1, 2, 3), 2, 3);

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

19. 基于if, else和else if的条件控制里,我们必须用空格间隔开语句和括号,大括号的开始 { 必须与条件控制语句位于同一行,结束 } 必须总是独占一行且顶格,控制流程内容必须用四个空格进行缩进,且不使用elseif.

if ($condition) { 
// ... 
} else if ($_condition) { 
// ... 
} else { 
// ... 
}
로그인 후 복사

20. 在条件控制语句的条件括号内,必须用空格将操作符与其它元素隔开,如果遇到很长的逻辑判断,则鼓励用内嵌括号来分割各个逻辑,例如:

if (($a != 2) and ($b == 1)) { 
$a = $b; 
}
로그인 후 복사

21. switch 条件控制语句中,必须用空格将待测参数与其它元素分隔开,例如:

switch ($num) { 
// …
}
로그인 후 복사

22. switch 语句的内容必须以四个空格缩进,case 条件控制的内容必须再加四个空格进行缩进,例如:

switch ($indentedSpaces) { 
case 2: 
echo 错误; 
break; 
case 4: 
echo 正确; 
break; 
default: 
break; 
} 
23. 在 switch 语句中应该总是包括 default 控制。
24. 有时候我们需要在 case 语境中省略掉 break 或 return ,这个时候我们必须为这些 case 语句加上 // 此处无break 注释,例如:
switch ($numPeople) { 
case 1: // 此处无break 
case 2: 
  break; 
default: 
  break; 
}
로그인 후 복사


永久链接:

转载随意!带上文章地址吧。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP 코드 사양의 7가지 원칙을 익히고 더욱 표준화된 코드를 작성하세요. PHP 코드 사양의 7가지 원칙을 익히고 더욱 표준화된 코드를 작성하세요. Jan 11, 2024 pm 02:34 PM

PHP 코드 사양의 7가지 원칙을 이해하고 보다 표준화된 코드를 작성하려면 구체적인 코드 예제가 필요합니다. 소개: PHP는 웹 개발 분야에서 널리 사용되는 프로그래밍 언어입니다. 올바른 형식의 코드를 작성하는 것은 고품질 애플리케이션 개발의 핵심입니다. 이 기사에서는 PHP 코드 사양의 7가지 원칙을 소개하고 개발자가 보다 표준화된 PHP 코드를 작성하는 데 도움이 되는 구체적인 코드 예제를 제공합니다. 1. 명명 규칙 좋은 명명 규칙은 표준화된 코드 작성의 기초입니다. 다음은 명명 규칙의 몇 가지 원칙입니다. 클래스 이름과 인터페이스 이름은 대문자로 시작하는 카멜 표기법을 사용합니다.

PHP 코드 사양의 예외 처리 규칙을 이해하고 적용합니다. PHP 코드 사양의 예외 처리 규칙을 이해하고 적용합니다. Aug 10, 2023 pm 05:13 PM

PHP 코드 사양의 예외 처리 규칙을 이해하고 적용합니다. 예외 처리는 프로그램에서 오류를 찾고, 찾고, 해결하는 데 효과적으로 도움이 됩니다. PHP 코드 사양은 읽기 쉽고 유지 관리가 가능하며 신뢰할 수 있는 코드를 작성하는 데 매우 유용한 표준 예외 처리 규칙 세트를 제공합니다. 이 문서에서는 이러한 규칙을 설명하고 코드 예제를 통해 설명합니다. 1. 예외 처리를 사용하는 경우 예외 처리 규칙을 이해하기 전에 먼저 예외 처리를 사용하는 경우를 명확히 해야 합니다. 예외 처리를 사용하여 처리해야 합니다.

PHP 작성 표준 준수: 팀워크 및 코드 공동 개발 기능 향상 PHP 작성 표준 준수: 팀워크 및 코드 공동 개발 기능 향상 Aug 25, 2023 pm 07:51 PM

PHP 작성 사양 준수: 팀워크 및 코드 공동 개발 기능 향상 소개: 소프트웨어 개발에서는 코드 품질과 팀워크가 중요합니다. 프로그래밍 표준을 준수하는 것은 코드 품질과 팀워크를 향상시키는 효과적인 수단 중 하나입니다. 이 기사에서는 PHP 작성 표준을 준수하여 팀워크와 코드 공동 개발 기능을 향상시키는 방법에 중점을 둘 것입니다. 1. 명명 규칙 좋은 명명 규칙은 코드의 가독성과 유지 관리 가능성을 높일 수 있습니다. PHP 프로그래밍에서는 다음과 같은 명명 규칙을 따르는 것이 좋습니다. 변수 및 함수에는 camelCase 명명을 사용합니다.

제안된 PHP 코드 사양이 개발 산업에 미치는 영향 평가 제안된 PHP 코드 사양이 개발 산업에 미치는 영향 평가 Aug 10, 2023 pm 01:28 PM

PHP 코드 사양 도입이 개발 산업에 미치는 영향 평가 소프트웨어 개발 산업의 지속적인 발전과 함께 코드 사양은 코드 품질, 가독성 및 유지 관리성을 향상시키는 중요한 수단이 되었습니다. PHP 개발 분야에서 PHP 코드 사양의 도입은 전체 개발 산업에 긍정적인 영향을 미쳤습니다. 이 기사에서는 제안된 PHP 코드 사양이 개발 산업에 미치는 영향을 여러 측면에서 평가하고 코드 예제를 통해 설명합니다. 코드 품질 향상 코드 사양은 통일된 명명 규칙, 코드 구조 및 주석 사양을 통해 코드 품질을 향상시킬 수 있습니다.

버전 관리의 후크 기능을 통해 코드가 최신 PHP 코드 사양을 준수하는지 자동으로 확인하는 방법은 무엇입니까? 버전 관리의 후크 기능을 통해 코드가 최신 PHP 코드 사양을 준수하는지 자동으로 확인하는 방법은 무엇입니까? Sep 05, 2023 pm 04:52 PM

버전 관리의 후크 기능을 통해 코드가 최신 PHP 코드 사양을 준수하는지 자동으로 확인하는 방법은 무엇입니까? 팀 협업과 개발이 점점 보편화되면서 코드 사양의 통일이 특히 중요해졌습니다. PHP 개발에 있어서 최신 PHP 코드 사양을 따르면 코드의 가독성과 유지 관리성이 향상되어 팀의 개발 효율성이 향상될 수 있습니다. 본 글에서는 버전 관리의 Hook 기능을 통해 해당 코드가 최신 PHP 코드 사양을 준수하는지 자동으로 확인하는 방법을 소개하고, 해당 코드 예제를 제공합니다. 1. 버전관리 버전관리 Hook 기능은 무엇인가요?

코드 검토를 위해 PHP 코드 표준을 사용하는 방법 코드 검토를 위해 PHP 코드 표준을 사용하는 방법 Aug 10, 2023 am 08:53 AM

코드 검토를 위해 PHP 코드 사양을 사용하는 방법 소개: PHP는 유연성과 강력한 기능으로 인해 많은 개발자가 웹 사이트와 애플리케이션을 구축하는 데 즐겨 사용하는 개발 언어입니다. 그러나 PHP의 유연성으로 인해 코드 불규칙성 및 품질 저하 문제가 발생하기 쉽습니다. 코드의 가독성, 유지 관리성 및 확장성을 보장하려면 코드 검토에 PHP 코드 사양을 사용해야 합니다. 이 기사에서는 일반적으로 사용되는 PHP 코드 사양을 소개하고 해당 코드 예제를 제공합니다.

PHP 프로그래밍 지침: 유효한 유효성 검사 문자열은 숫자와 문자로 제한됩니다. PHP 프로그래밍 지침: 유효한 유효성 검사 문자열은 숫자와 문자로 제한됩니다. Mar 29, 2024 am 08:54 AM

프로그래밍 분야는 특히 PHP 애플리케이션을 개발할 때 코드 품질과 유지 관리성을 보장하는 데 중요합니다. 일반적인 요구 사항 중 하나는 입력 문자열을 효율적으로 검증하여 숫자와 알파벳 문자만 포함되어 있는지 확인하는 것입니다. 이 기사에서는 프로그래밍 규칙을 준수하면서 이 요구 사항을 달성하기 위해 PHP에서 코드를 작성하는 방법을 소개합니다. 프로그래밍 표준 개요 PHP 프로그래밍에서 특정 프로그래밍 표준을 따르면 코드를 더 쉽게 읽고 유지 관리할 수 있을 뿐만 아니라 오류를 줄이고 코드 성능을 향상시키는 데도 도움이 됩니다. 다음은 몇 가지 프로그래밍 지침 권장 사항입니다. 의도적인 사용

PHP 코드 사양을 통해 코드 테스트 가능성을 향상시키는 방법 PHP 코드 사양을 통해 코드 테스트 가능성을 향상시키는 방법 Aug 13, 2023 am 11:52 AM

PHP 코드 사양을 통해 코드 테스트 가능성을 향상시키는 방법 요약: 개발자가 테스트 가능한 코드를 작성하는 것은 매우 중요합니다. 이 기사에서는 코드 예제와 함께 일부 PHP 코딩 표준을 따라 코드의 테스트 가능성을 향상시키는 방법을 소개합니다. 소개: 현대 소프트웨어 개발에서 테스트 가능성은 매우 중요한 요소가 되었습니다. 테스트 가능한 코드를 사용하면 더 빠르게 디버깅하고 문제를 해결할 수 있을 뿐만 아니라 더 높은 품질의 소프트웨어를 제공할 수 있습니다. PHP 개발에서 우리는 다음을 개선할 수 있습니다.

See all articles