JavaScript의 문자열에서 악센트 및 발음 구별 부호 제거
문자열에서 강조된 문자를 제거하는 것은 정렬 및 검색 작업과 같은 작업에 필수적입니다. JavaScript에서는 이를 달성하기 위한 다양한 접근 방식이 있습니다.
정규 표현식 사용
한 가지 일반적인 방법은 정규 표현식을 사용하여 악센트가 있는 문자를 악센트가 없는 해당 문자로 바꾸는 것입니다. 그러나 IE6과 같은 이전 브라우저에서는 정규식에 문제가 발생할 수 있습니다.
Leveraging String.prototype.normalize()
ES2015에서는 String.prototype.normalize()를 도입했습니다. 유니코드 문자열의 정규화를 허용하는 메서드입니다. "NFD" 형식으로 정규화하면 결합된 문자소를 더 간단한 문자소로 분해할 수 있습니다. 이를 통해 특정 유니코드 문자를 필터링하여 쉽게 발음 구별 부호를 제거할 수 있습니다.
const str = "Crème Brûlée"; str.normalize("NFD").replace(/[\u0300-\u036f]/g, ""); // "Creme Brulee"
또는 유니코드 속성 이스케이프를 사용할 수도 있습니다.
str.normalize("NFD").replace(/\p{Diacritic}/gu, "");
악센트 및 발음 구별 부호를 사용하여 문자열 정렬
정렬 목적으로 다음을 사용할 수 있습니다. 악센트 및 발음 구별 부호 정규화를 처리하는 Intl.Collator 객체.
const c = new Intl.Collator(); [...names].sort(c.compare); // Sorts names without considering accents or diacritics
또한 기본적으로 악센트 및 발음 구별 부호를 고려하는 String.prototype.localeCompare()를 사용할 수 있습니다.
[...names].sort((a, b) => a.localeCompare(b));
요약하면 String.prototype.normalize() 또는 Intl.Collator를 사용하면 악센트 및 악센트 변형의 영향을 받지 않고 문자열의 발음 구별 부호 또는 문자열 정렬.
위 내용은 JavaScript의 문자열에서 악센트 및 분음 부호를 어떻게 제거할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!