> 웹 프론트엔드 > JS 튜토리얼 > JavaScript에서 이스케이프된 유니코드 문자열을 디코딩하는 방법은 무엇입니까?

JavaScript에서 이스케이프된 유니코드 문자열을 디코딩하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-07 11:32:03
원래의
917명이 탐색했습니다.

How to Decode Escaped Unicode Strings in JavaScript?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿