한동안 PHP로 개발을 했다면 PSR-12라는 용어를 접했을 것입니다. 이는 PHP 커뮤니티에서 가장 널리 받아들여지는 코딩 표준 중 하나이며 다양한 프로젝트에서 PHP 코드베이스의 일관성을 보장하는 것을 목표로 합니다. 단독으로 작업하든 팀의 일원으로 작업하든 PSR-12를 따르면 코드가 더 깔끔하고, 읽기 쉽고, 유지 관리하기 쉬워집니다. 이 블로그에서는 PSR-12가 무엇인지, 왜 중요한지, 프로젝트에 PSR-12를 적용하는 방법에 대해 자세히 설명하겠습니다.
PSR-12는 PHP-FIG(Framework Interoperability Group)에서 개발한 PHP용 코딩 스타일 가이드입니다. 이전 PSR-2 표준을 기반으로 구축되어 최신 PHP 관행을 반영하고 코드베이스 전체의 일관성을 향상시키는 업데이트된 규칙 세트를 제공합니다.
PSR-12를 깔끔하고 읽기 쉽고 유지 관리 가능한 PHP 코드 작성을 위한 청사진으로 생각해 보세요. PSR-12를 따르면 개발자는 자신의 코드가 표준화된 구조를 준수하는지 확인할 수 있으므로 다른 사람과 더 쉽게 협업하고 오픈 소스 프로젝트를 진행할 수 있습니다.
PSR-12와 같은 코딩 표준은 단지 공백과 탭에 대한 문제를 해결하는 것이 아닙니다. 중요한 이유는 다음과 같습니다.
PSR-12가 제시하는 몇 가지 주요 규칙을 살펴보겠습니다. 작은 지침도 많지만 가장 눈에 띄는 지침은 다음과 같습니다.
PSR-12에서는 명확성을 높이기 위해 네임스페이스와 사용 선언이 특정 순서를 따라야 합니다.
예:
<?php namespace App\Controllers; use App\Models\User; use App\Repositories\UserRepository; class UserController { // Class implementation }
PSR-12는 클래스, 속성 및 메서드 선언 방법에 대해 몇 가지 엄격한 규칙을 적용합니다.
class UserController { private $userRepository; public function __construct(UserRepository $userRepository) { $this->userRepository = $userRepository; } } <h4> 4. 제어 구조 </h4> <p>if, for, switch와 같은 제어 구조는 특정 규칙을 따라야 합니다.</p> <ul> <li> <strong>구조</strong>: 제어 키워드와 여는 괄호 사이에 공백이 하나 있어야 합니다. 한 줄 문에도 중괄호 {}를 항상 사용해야 합니다.</li> <li> <strong>들여쓰기</strong>: 제어 구조 내부의 모든 블록은 한 수준(일반적으로 공백 4개)만큼 들여쓰기되어야 합니다. </li> </ul> <pre class="brush:php;toolbar:false">if ($user->isAdmin()) { echo "User is an admin"; } else { echo "User is not an admin"; }
코멘트는 코드의 특정 부분이 존재하는 이유를 설명하는 데 매우 중요합니다. PSR-12는 적절하고 명확한 설명의 필요성을 강조합니다.
<?php namespace App\Controllers; use App\Models\User; use App\Repositories\UserRepository; class UserController { // Class implementation }
프로젝트에서 PSR-12를 따르려면 코드를 작성할 때 지침을 수동으로 준수할 수 있지만 규정 준수를 보장하는 가장 좋은 방법은 자동화된 도구를 사용하는 것입니다.
먼저 다음과 같은 일반적인 관행을 숙지하세요.
코드가 PSR-12를 따르는지 수동으로 확인하는 것은 시간이 많이 걸릴 수 있지만 이 프로세스를 자동화하는 데 도움이 되는 도구가 있습니다.
PHP 코드가 PSR-12를 따르도록 하는 가장 인기 있는 도구 중 하나는 PHP_CodeSniffer입니다. 코드를 분석하고 표준에서 벗어나는 부분을 지적합니다.
설치 및 사용 방법:
class UserController { private $userRepository; public function __construct(UserRepository $userRepository) { $this->userRepository = $userRepository; } }
그런 다음 코드에 대해 실행하세요.
if ($user->isAdmin()) { echo "User is an admin"; } else { echo "User is not an admin"; }
또 다른 유용한 도구는 PHP CS Fixer입니다. 문제를 감지할 뿐만 아니라 자동으로 PSR-12를 준수하도록 코드를 수정할 수도 있습니다.
// Fetch user from the repository $user = $userRepository->find($id); /* * If user is not found, throw an exception. * This helps in handling invalid user IDs. */ if (!$user) { throw new NotFoundException(); }
다음을 사용하여 Fixer를 실행하세요.
composer require "squizlabs/php_codesniffer=*"
PHPStorm을 사용하는 경우 PSR-12를 따르도록 구성할 수 있습니다. 설정으로 이동 -> 편집자 -> 코드 스타일 -> PHP 표준을 PSR-12로 설정합니다.
PHP 프로젝트에서 PSR-12를 따르는 것은 단순히 임의의 규칙을 준수하는 것 이상입니다. 혼자 작업하든 팀과 함께 작업하든 상관없이 코드를 더 깔끔하고, 읽기 쉽고, 유지 관리하기 쉽게 만드는 것입니다. PSR-12를 따르면 자신뿐만 아니라 전체 PHP 커뮤니티를 위한 코드를 작성하게 됩니다.
이 표준을 채택하는 것은 전문적이고 일관되며 유지 관리가 가능한 PHP 코드를 작성하기 위한 단계입니다. 언급된 도구를 사용하여 프로세스를 더 쉽게 만들고 프로젝트가 얼마나 깔끔하고 정리되는지 확인해 보세요!
즐거운 코딩하세요!
위 내용은 PSR 이해 - PHP 코딩 스타일 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!