>웹 프론트엔드 >JS 튜토리얼 >js 문자열을 json 객체로 변환하는 방법 및 주의사항

js 문자열을 json 객체로 변환하는 방법 및 주의사항

yulia
yulia원래의
2018-09-14 14:31:102289검색

작업 중에 JS 문자열을 JSON 개체로 변환해야 하는 경우가 많습니다. 다음으로 JS 문자열을 JSON으로 변환하는 몇 가지 방법을 소개하겠습니다. 이 튜토리얼에는 필요한 참고 자료가 있습니다. 그것을 참조하십시오.

1, 평가 방법 분석, 이것이 가장 초기의 분석 방법인 것 같습니다. 다음과 같습니다:

function strToJson(str){ 
var json = eval('(' + str + ')'); 
return json; 
}

str의 양쪽에 있는 괄호를 잊지 마세요.

2. 새로운 함수 형식이 꽤 이상합니다. 아래와 같이

unction strToJson(str){ 
var json = (new Function("return " + str))(); 
return json; 
}

3과 같이 전역 JSON 객체를 다음과 같이 사용합니다.

function strToJson(str){ 
return JSON.parse(str); 
}

현재 IE8(S)/Firefox3.5+/Chrome4/Safari4/Opera10에서는 이 방법을 구현했습니다.

JSON.parse를 사용하려면 JSON 사양을 엄격히 준수해야 합니다. 예를 들어 속성은 아래와 같이 따옴표로 묶어야 합니다.

ar str = '{name:"jack"}'; 
var obj = JSON.parse(str); // --> parse error

이름은 따옴표로 묶지 않습니다. JSON.parse를 사용하면 예외가 발생합니다. 모든 브라우저에서 구문 분석이 실패합니다. 처음 두 가지 방법은 괜찮습니다.

참고 사항:

1. 백엔드에서 프런트엔드로 전달되는 문자열은 단지 문자열일 뿐입니다. 또한 JSON.parse(jsonStr)를 사용하여 백엔드를 변환할 수 있습니다. 문자열을 js 객체로 변환합니다. json 문자열은 프런트엔드 json 객체로 변환됩니다.
2. json 문자열의 철자에도 주의해야 합니다. 속성과 값은 작은따옴표로 묶습니다. 축하합니다! 함정에 빠지면 프런트에서 제대로 분석할 수 없습니다.
3. 마지막으로 Java 백엔드 문자열의 따옴표에는 전송 문자 ""를 사용해야 한다는 점을 언급하는 것이 중요합니다.

위 내용은 js 문자열을 json 객체로 변환하는 방법 및 주의사항의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.