JavaScript에서 인코딩된 유니코드 문자열 디코딩
인코딩된 유니코드 문자가 포함된 문자열로 작업할 때 해당 문자를 올바르게 디코딩하는 것이 어려울 수 있습니다. 이 문서에서는 이스케이프된 유니코드 문자로 인코딩된 문자열을 디코딩하는 문제를 다룹니다.
질문에 설명된 특정 문제는 httpu00253Au00252Fu00252Fexample.com과 유사한 문자열과 관련이 있습니다. unescape, decodeURI, decodeURIComponent 등 다양한 방법을 시도한 후 제안된 해결 방법은 문자열 대체를 사용하는 것입니다.
단, 초기 조건을 고려하는 것이 중요합니다. 문제의 문자열은 직접 입력되지 않고 대신 다음 예에서 볼 수 있듯이 다른 코드 조각에서 얻은 하위 문자열입니다.
var s = 'http\u00253A\u00252F\u00252Fexample.com';
이것은 unescape()가 예상한 결과를 산출하지 않는 이유를 설명합니다.
이러한 문자열을 디코딩하는 핵심은 JSON.parse를 활용하는 것입니다. 인코딩된 문자열을 큰따옴표로 캡슐화하고 JSON으로 구문 분석하면 브라우저가 자동으로 유니코드 문자를 디코딩합니다. 다음 예는 이 접근 방식을 보여줍니다.
unescape(JSON.parse('"http\u00253A\u00252F\u00252Fexample.com"')); // Output: 'http://example.com'
이 경우 unescape()는 잠재적으로 남아 있는 이스케이프 시퀀스를 제거하는 데 사용됩니다. unescape()는 브라우저가 아닌 환경에서는 더 이상 사용되지 않으며 TypeScript에는 존재하지 않습니다. 더 넓은 호환성을 위해서는 대신 decodeURIComponent를 사용하는 것이 좋습니다.
위 내용은 JavaScript에서 이스케이프된 유니코드 문자열을 디코딩하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!