웹 개발 영역에서 JSON.stringify 함수는 JavaScript 개체를 JSON 문자열로 변환하는 강력한 도구입니다. 그러나 기본 Error 개체를 문자열화하려고 하면 비정상적인 동작이 발생합니다. 예상되는 오류 정보 대신 빈 개체가 반환됩니다.
이 현상을 자세히 알아보려면 다음 코드 조각을 고려하세요.
const error = new Error('simple error message'); console.log(JSON.stringify(error)); // Outputs: '{}'
As 위에서 설명한 것처럼 JSON.stringify는 빈 개체를 반환하며 이는 기본 Error 개체의 속성이 문자열화되지 않았음을 나타냅니다. 이 동작은 Error 개체에 열거 가능한 속성이 없기 때문에 발생합니다.
이를 확인하려면 Object.getOwnPropertyNames를 사용하여 Error 개체에 정의된 속성의 이름을 검색할 수 있습니다.
console.log(Object.getOwnPropertyNames(error)); // Outputs: ['stack', 'arguments', 'type', 'message']
그러나 속성 설명자를 검사하면 모든 속성에 대해 열거 가능 속성이 false로 설정되어 있음을 알 수 있습니다. 속성:
for (var property in error) { var descriptor = Object.getOwnPropertyDescriptor(error, property); console.log(property, descriptor); }
열거 가능한 속성이 부족함에도 불구하고 JSON.stringify를 사용하여 기본 Error 개체를 문자열화하는 해결 방법이 있습니다.
JSON.stringify(err, Object.getOwnPropertyNames(err))
JSON.stringify의 두 번째 인수로 속성 이름 목록을 제공함으로써 속성 이름 목록을 문자열화 프로세스에 포함하도록 명시적으로 지시합니다. 기본적으로 열거할 수는 없지만
위 내용은 기본 오류 개체를 문자열화할 때 JSON.stringify가 빈 개체를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!