>  기사  >  백엔드 개발  >  PHP 코딩 스타일 사양을 정말로 이해하고 있습니까?

PHP 코딩 스타일 사양을 정말로 이해하고 있습니까?

王林
王林앞으로
2019-08-27 18:01:141964검색

PHP의 유연성으로 인해 많은 사람들이 코드를 작성할 때 좋은 코드 사양에 주의를 기울이지 않아 이미 유연한 PHP 코드가 지저분해 보입니다. 실제로 PSR 사양의 PSR-1과 PSR-2는 다음과 같이 정의되어 있습니다. PHP 코딩에는 몇 가지 사양이 있습니다. 이러한 사양만 잘 따르면 유연한 스크립트 언어를 사용해도 매우 아름답고 깔끔한 코드를 작성할 수 있습니다. 먼저 통과된 PSR 사양을 살펴보고 PSR-1 및 PSR-2 사양의 구체적인 요구 사항을 간략하게 설명하겠습니다.

통과된 PSR:

PHP 코딩 스타일 사양을 정말로 이해하고 있습니까?

PSR-1 기본 인코딩 사양:

1. 태그 열기 및 닫기
먼저 PHP 코드는

2. 부작용
PHP 파일은 클래스, 인터페이스, 함수 등을 선언하거나 논리적 작업(예: 파일 읽기 및 쓰기 또는 브라우저에 출력 보내기)을 수행해서는 안 됩니다. 둘 다 동시에.

3. 이름 지정
클래스 이름 지정은 대문자로 시작하는 카멜 케이스 명명 규칙을 준수해야 합니다. 즉, 클래스 이름은 대문자로 시작해야 합니다. 속성 이름을 지정할 필요는 없지만 일관성이 있어야 합니다. 메소드 이름은 소문자로 시작하는 camelCase 명명 규칙을 따라야 합니다. 클래스 상수의 모든 문자는 대문자로 시작해야 하며 단어는 밑줄로 구분됩니다.

PSR2 코딩 스타일 사양:

1. PSR-1은 태그로 끝나서는 안 되며, 빈 줄로 끝나야 한다고 규정합니다.

2. 네임스페이스 선언 뒤에는 빈 줄이 삽입되어야 하며, 사용 선언 블록 뒤에도 빈 줄이 있어야 합니다. 동일한 코드 줄에 여러 개의 use 문을 만들지 마세요.

3. class
class 키워드, 클래스 이름, 확장 및 구현 키워드의 시작과 끝은 같은 줄에 있어야 합니다. 클래스가 여러 인터페이스를 구현하는 경우 인터페이스 이름은 클래스 선언의 같은 줄에 있거나 별도의 줄을 차지할 수 있습니다. 이러한 인터페이스 이름을 여러 줄에 배치하도록 선택한 경우 첫 번째 인터페이스 이름은 자체 줄에 있어야 하며 Implements 키워드 뒤에 오면 안 됩니다. 클래스의 여는 중괄호({)는 함수 선언 뒤의 한 줄에 작성해야 하며, 닫는 중괄호(})도 클래스 본문 뒤의 한 줄에 작성되어야 합니다. 즉, 클래스 선언은 다음과 같습니다.

class EarthGame extends Game implements
    Playable,   
    Savable
{    
    //类体
}

클래스 선언과 같은 줄에 클래스 이름을 넣을 수도 있습니다.

class EarthGame extends Game implements Playble, Savable
{     
    //类体
}

4. 속성 선언
각 속성에는 액세스 수정자(공개, 비공개 또는 보호)가 있어야 합니다. var 키워드를 사용하여 속성을 선언할 수 없습니다. 속성 이름의 사양은 이미 PSR-1에서 다룹니다. 밑줄, 소문자 카멜케이스 이름 지정 또는 대문자 카멜케이스 이름 지정을 사용할 수 있지만 일관성을 유지해야 합니다. (개인적으로 속성에는 소문자 카멜 케이스 사용을 권장합니다)

5. 메소드의 시작과 끝
모든 메소드에는 접근 수정자(public, private 또는 protected)가 있어야 합니다. 액세스 한정자는 abstract 또는 final 뒤, static 앞에 와야 합니다. 기본값이 있는 메소드 매개변수는 매개변수 목록의 마지막에 배치되어야 합니다.

한 줄 선언
메서드의 여는 중괄호({)는 메서드 이름 뒤에 한 줄에 써야 하고, 닫는 중괄호(})도 메서드 본문 뒤에 한 줄에 써야 합니다( 메소드 코드 바로 뒤에 있음). 메소드 매개변수 목록은 공백으로 시작하거나 끝나서는 안 됩니다. 즉, 매개변수 목록은 괄호 뒤에 와야 합니다. 각 매개변수에 대해 매개변수 이름(또는 기본값) 뒤에는 쉼표가 있어야 하고, 쉼표 뒤에는 공백이 있어야 합니다. 아래와 같이 복잡하게 들릴 수 있습니다.

final public static function generateTile(int $diamondCount, bool $polluted = false)
{
   //方法体
 }

여러 줄 선언
메서드에 매개 변수가 많은 경우 한 줄 메서드 선언은 실용적이지 않습니다. 이 시점에서 각 매개변수(유형, 매개변수 변수, 기본값 및 쉼표 포함)가 별도의 들여쓰기 줄에 있도록 매개변수 목록을 분할할 수 있습니다. 이 경우, 닫는 괄호는 매개변수 목록 다음 줄에 위치해야 하며 메서드 선언의 시작 부분에 맞춰 정렬되어야 합니다. 여는 중괄호({)는 같은 줄에서 닫는 괄호 다음에 공백으로 구분되어야 합니다. 메소드 본문은 새 줄에서 시작해야 합니다. 다시 말하지만 이는 복잡하게 들릴 수 있지만 다음 예는 이 규칙을 이해하는 데 도움이 될 것입니다.

public function __construct(
    int $size,
    string $name,
    bool $warparound = false,
    bool $aliens = false
) {  
    //方法体
   }

6. 줄과 들여쓰기
코드는 탭 대신 공백 4개를 사용하여 들여쓰기해야 합니다. 편집기 설정을 확인하고 탭 키를 눌렀을 때 탭 대신 공백 4개를 사용하도록 설정할 수 있습니다. 각 코드 줄은 120자를 초과할 수 없습니다.

7、方法与函数调用
方法名称和开始圆括号之间不能有空格。方法调用中的参数列表的规则与方法声明中的参数列表规则相同。换言之,对于单行调用,开始圆括号后或结束圆括号前不能有空格。每个参数之后应该紧跟一个逗号,下一个参数前应该有一个空格。如果需要使用多行代码进行方法调用,那么每个参数应该自成一行并缩进,而且结束圆括号也应该自成一行。

$earthGanme = new EarthGame(   
   5,
   'earth', 
   true,
   true
);
$earthGame::generateTile(5, true);

8、流程控制
流程控制关键字(if、for、while等)后面必须紧跟一个空格。但是,开始圆括号后不能有空格。同样,结束圆括号前不能有空格。因此内容应该紧贴在括号内的。与类和(单行)函数声明相比,流程控制代码的开始花括号应该与结束圆括号在同一行。结束花括号应该自成一行。以下是一个简单的示例。

$title = [];for ($x = 0; $x < $diamondCount; $x++) {    if ($polluted) {
        $title[] = new PollutionDecorator(new DiamondDecorator(new Plains()));
    } else {
        $title[] = new DiamondDecorator(new Plains());
    }
}

想了解更多相关问题请访问PHP中文网:PHP视频教程

위 내용은 PHP 코딩 스타일 사양을 정말로 이해하고 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제