>웹 프론트엔드 >JS 튜토리얼 >jquery eval_jquery로 JSON을 구문 분석할 때 주의할 점 소개

jquery eval_jquery로 JSON을 구문 분석할 때 주의할 점 소개

WBOY
WBOY원래의
2016-05-16 17:24:30878검색

JS에서 JSON 문자열을 JSON 데이터 형식으로 구문 분석하는 방법에는 일반적으로 두 가지가 있습니다.

1. 하나는 eval() 함수를 사용하는 것입니다.

2. 함수 객체를 사용하여 반환 분석을 수행합니다.

eval 함수를 사용하여 파싱하고, jquery의 각 메소드를 사용하여 순회합니다.

jquery를 사용하여 JSON 데이터를 파싱하며, jquery 비동기 요청, jquery 요청의 전송 개체로 반환된 결과는 json 개체입니다. 여기서 고려되는 것은 JSON 형식으로 서버에서 반환되는 문자열입니다. JSONObject와 같은 플러그인으로 캡슐화된 JSON 개체의 경우 이와 유사하므로 여기서는 설명하지 않습니다.
여기서 먼저 JSON 문자열 세트가 제공됩니다.

코드는 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

var data="
{
root:
[
{name:'1',value :'0'},
{이름:'6101',값:'Beijing'},
{이름:'6102',값:'Tianjin'},
{이름:'6103', 값:'상하이' },
{이름:'6104', 값:'충칭시'},
{이름:'6105',값:'웨이난시'},
{이름:' 6106',value: 'Yan'an City'},
{name:'6107',value:'Hanzhong City'},
{name:'6108',value:'Yulin City'},
{이름:'6109 ',값:'안강시'},
{이름:'6110',값:'상뤄시'}
]
}";

여기서는 jquery asynchronous 획득한 데이터 유형인 json 객체와 문자열을 기준으로 두 가지 방법으로 얻은 결과를 처리하는 방법을 각각 소개합니다.

1. 서버에서 반환된 JSON 문자열의 경우 jquery 비동기 요청이 유형을 지정하지 않거나 문자열 형식으로 허용하는 경우 메서드가 너무 객체화되어야 합니다. 번거로운 일, 즉 문자열을 변환하여 eval()에 넣고 한 번 실행해 보세요. 이 방법은 일반 javascipt 방법으로 json 개체를 얻는 데에도 적합합니다. 다음 예에서는

var dataObj=eval("(" data ")");//Convert to json 개체
이유를 설명합니다. 여기서 평가해야 합니까? "("(" data ")");//"를 추가하는 것은 어떻습니까?

이유는 eval 자체의 문제입니다. json은 "{}"으로 시작하고 끝나기 때문에 JS에서는 명령문 블록으로 처리되므로 강제로 표현식으로 변환해야 합니다.

괄호를 추가하는 목적은 JavaScript 코드를 명령문으로 실행하는 대신 eval 함수가 JavaScript 코드 처리 시 괄호 안의 표현식을 객체로 변환하도록 강제하는 것입니다. 예를 들어 객체 리터럴 {}을 사용하면 외부 대괄호가 추가되지 않으면 eval은 중괄호를 JavaScript 코드 블록의 시작 및 끝 표시로 인식하고 {}는 빈 문을 실행하는 것으로 간주됩니다. 따라서 다음 두 가지 실행 결과는 다릅니다.
코드 복사 코드는 다음과 같습니다.

Alert( eval("{}"); // 정의되지 않은 반환
alert(eval("({})");// return object[Object]

이 작성 ​​방법의 경우, JS에서는 다음과 같은

어디에서나 볼 수 있습니다. (function()) {}(); 클로저 작업을 수행할 때 등 ---------------- --------------------- ---------------

코드 복사 코드는 다음과 같습니다.
alert(dataObj.root.length);/ /루트의 하위 객체 수 출력
$.each(dataObj.root,fucntion(idx,item){
if(idx==0){
return true;
}
//각 루트 하위 객체의 이름과 값을 출력
alert("name:" item.name ",value:" item.value)
} )

참고: 일반 js에서 json 객체를 생성하려면 $.each() 메서드만 for 문으로 바꾸면 되고 나머지는 변경되지 않습니다.

2. 반환된 JSON 문자열은 다음과 같습니다. jquery 비동기 요청이 유형(일반적으로 이 구성 속성)을 "json"으로 설정하거나 $.getJSON() 메서드를 사용하여 서버 반환을 얻는 경우 eval() 메서드는 필요하지 않습니다. 획득한 객체는 이미 json 객체입니다. 여기서는 $.getJSON 메서드를 예로 사용하여 데이터 처리 방법을 설명합니다.

코드 복사 코드는 다음과 같습니다.
$.getJSON("http://www.phpzixue.cn/",{param:"gaoyusi"} ,function(data){
//여기에 반환된 데이터는 이미 json 객체입니다
//다음 다른 작업은 첫 번째 경우와 동일합니다
$.each(data.root,function(idx ,item){
if(idx ==0){
return true;//countinue와 동일, break와 동일하게 false 반환
}
alert("name:" item.name " ,값:" item.value);
} );
});


여기서 특별한 주의가 필요한 것은 방법 1의 eval() 메서드가 문자열(아마도 js 스크립트)을 동적으로 실행하므로 시스템 보안 문제가 쉽게 발생할 수 있다는 것입니다. 따라서 eval()을 우회하는 일부 타사 클라이언트 스크립트 라이브러리를 사용할 수 있습니다. 예를 들어 JavaScript의 JSON은 3k 이하의 스크립트 라이브러리를 제공합니다.

두 번째 구문 분석 방법은 Function 객체를 사용하는 것입니다. 일반적인 응용 프로그램은 JQUERY
코드 복사 코드는 다음과 같습니다.
var json='{"name":"CJ","age":18}'
data =(new Function("","return " json))();

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