str_starts_with()
함수 사용법
str_starts_with()
함수는
문자열이 특정 문자열로 시작하는지 체크합니다.
특정 문자열로 시작하면 true
를 반환하고, 그렇지 않으면 false
를 반환합니다.
이 함수는 대소문자를 구분합니다.
PHP 8에서 도입된 함수로 PHP 8 이전의 버전에서는 호환되지 않습니다.
문자열이 특정 문자열로 끝나는지 체크하려면 str_ends_with()
함수를 사용하세요.
str_starts_with()
함수의 형식은 다음과 같습니다.
구문
매개변수
$haystack |
검색 대상이 되는 문자열입니다. |
---|---|
$needle |
검색할 문자열입니다.
대소문자를 구분합니다. |
반환 값
검색 대상이 되는 문자열에서 검색할 주어진 문자열이 포함되어 있으면 true
를 그렇지 않으면 false
를 반환합니다.
검색할 주어진 문자는 대소문자를 구분합니다.
검색할 문자열이 빈 문자열(''
)일 경우
빈 문자열(''
)은 모든 문자열의 시작 부분에 있다고 간주되므로, 빈 문자열을 $haystack
으로 사용하면 항상 true
를 반환합니다.
이러한 동작은 문자열의 논리적 정의에 근거합니다. 빈 문자열은 어떤 문자열의 시작 부분이나 끝 부분에 존재하므로, 빈 문자열로 시작하거나 끝나는 모든 문자열에 대해 true
를 반환하는 것이 자연스러운 결과입니다. 따라서, 이 개념은 PHP뿐만 아니라 여러 프로그래밍 언어에서 보편적으로 적용됩니다.
Polyfill
PHP 8에서 도입된 함수로 PHP 8 이전의 버전에서는 호환되지 않습니다.
PHP 8 이전의 버전에서는 호환되지(지원하지) 않기 때문에 PHP 8 이전의 버전에서는 다음과 같이 사용할 수도 있습니다.
일러두기
아래의 예제 코드는 PHP 8 이전 버전에서 str_starts_with()
함수를 대체하기 위한 간단한 polyfill 예제입니다. 완벽하지 않습니다.
이 polyfill은 간단한 사용 사례에 맞추어 작성되었지만, 특정 사용자의 요구 사항(PHP 버전, 성능 고려, 대소문자 구분, 빈 문자열 처리, 다국어 문자열 처리, 기타 상황 등)에 따라 유연성을 추가할 필요가 있을 수 있습니다.
코드 부연설명
mb_strpos()
함수는 문자열에서 특정 문자열의 위치를 찾는 함수입니다. 대소문자를 구분합니다. multi-byte 문자열에서 안전하게 작동합니다.
PHP 버전
- PHP 8 버전부터 지원합니다.