>  기사  >  웹 프론트엔드  >  js는 eval을 사용하여 json을 구문 분석합니다(js에서 json 사용)_javascript 기술

js는 eval을 사용하여 json을 구문 분석합니다(js에서 json 사용)_javascript 기술

WBOY
WBOY원래의
2016-05-16 17:03:27983검색

먼저 eval의 사용법에 대해 이야기해 보겠습니다. 내용이 익숙하신 분은 건너뛰셔도 됩니다.
eval 함수는 s가 문자열이 아닌 경우 s를 직접 반환합니다. . 그렇지 않으면 s 문을 실행합니다. s 문의 실행 결과가 값이면 이 값을 반환하고, 그렇지 않으면 정의되지 않은 값을 반환합니다. 객체 선언 구문 "{}"은 값을 반환할 수 없다는 점에 유의하는 것이 중요합니다. 값을 반환하려면 간단한 예를 들면 다음과 같습니다.

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

var s1='"a" 2' ; // 표현식
var s2='{a:2}'; //명령어
alert(eval(s1)) //->'a2'
alert(eval(s2)) ; / /->정의되지 않음
alert(eval('(' s2 ')')) //->[객체 객체]

보시다시피 객체 선언문은 실행만 되고 값을 반환할 수 없습니다.

"{}"와 같이 일반적으로 사용되는 객체 선언문을 반환하려면 해당 값을 반환하기 전에 괄호로 묶어 표현식으로 변환해야 합니다. 이는 Ajax 개발에 JSON을 사용하는 기본 원칙 중 하나이기도 합니다. 두 번째 경고 문은 정의되지 않음을 출력하고, 괄호를 추가한 후 세 번째 경고 문은 문이 나타내는 개체를 출력하는 것을 예제에서 명확하게 볼 수 있습니다.
이제 이 글의 초점인 함수 내에서 전역 코드를 실행하는 방법에 대해 이야기해 보겠습니다. 이 문제를 설명하기 위해 예를 살펴보겠습니다.

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

var s='global' // 전역 변수 정의
function deco1(){
eval('var s="local"');
}
demo1();
alert(s); ;글로벌

이해하기 쉽습니다. 위의 데모1 함수는 지역 변수 s를 정의하는 function deco1(){var s='local';}과 동일합니다.
그러므로 최종 출력이 전역 변수라는 것은 놀라운 일이 아닙니다. 결국 모든 사람이 지역 변수와 전역 변수를 명확하게 구분할 수 있습니다.
자세히 경험해 보면 eval 함수의 특징을 알 수 있습니다. 이는 항상 호출되는 컨텍스트 변수 공간(패키지, 클로저라고도 함) 내에서 실행됩니다. 이는 변수 정의이든 마찬가지입니다. 또는 함수 정의이므로 다음과 같습니다. 코드에서 정의되지 않은 함수 오류가 발생합니다.

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

var s='function test(){ return 1; }'; //함수 정의문
function deco2(){
eval(s);
}
demo2();
alert(test()) / /-> ;오류:테스트가 정의되지 않았습니다

테스트 함수가 로컬 공간에 정의되어 있어 데모2 함수 내에서는 접근이 가능하지만 외부에서는 접근이 불가능하기 때문입니다.

공유: JS의 eval을 사용하여 JSON을 구문 분석할 때 주의할 점
JS에서 JSON 문자열을 JSON 데이터 형식으로 구문 분석하는 방법에는 일반적으로 두 가지가 있습니다.

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

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

eval 함수를 사용하여 구문 분석하고 jquery의 각 메서드를 사용하여 순회합니다.

jquery를 사용하여 JSON 데이터를 구문 분석합니다. jquery 요청 후 반환되는 결과는 json 개체입니다. 여기서 고려되는 것은 플러그를 사용하여 서버에서 반환하는 문자열 형식입니다. - JSONObject와 같은 기능 JSON 객체도 이와 비슷하므로 여기서는 설명하지 않겠습니다.
여기서 먼저 JSON 문자열 세트가 제공됩니다. 문자열 세트는 다음과 같습니다.

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

var data="
{
root :
[
{이름:'1',값:'0'},
{이름:'6101',값:'Beijing'},
{이름:'6102 ', 값:'Tianjin City'},
{name:'6103',value:'Shanghai City'},
{name:'6104',value:'Chongqing City'},
{ 이름: '6105',값:'웨이난시'},
{이름:'6106',값:'옌안시'},
{이름:'6107',값:'한중시' },
{이름:'6108',값:'위린시'},
{이름:'6109',값:'안강시'},
{이름:'6110',값: '상뤄시' }
]
}";

jquery에서 비동기적으로 얻은 데이터 유형인 json 개체와 문자열을 기반으로 두 가지 방법으로 얻은 결과를 처리하는 방법을 소개합니다.

1. 서버에서 반환된 JSON 문자열의 경우 jquery 비동기 요청에 유형 설명이 없거나 문자열로 허용되는 경우 메서드가 너무 번거롭지 않아야 합니다. eval()에 문자열을 넣으면 한 번 실행됩니다. 이 방법은 일반적인 javascipt를 사용하여 json 객체를 얻는 데에도 적합합니다. 다음은 예입니다.

var dataObj=eval("(" data ")");//json 객체로 변환

평가에 "("(" data ")");//"를 추가해야 하는 이유는 무엇인가요?

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

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

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

alert( eval("{}"); // 정의되지 않은 반환
alert(eval("({})"); // 객체 반환[객체]

이런 글은 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() 메서드를 사용하여 서버 반환을 얻는 경우 이때 얻은 결과는 이미 json 개체이므로 eval() 메서드가 필요하지 않으며 개체를 직접 호출하기만 하면 됩니다. 여기서는 데이터 처리 방법을 설명하기 위해 $.getJSON 메서드를 예로 사용합니다.


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


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

두 번째 구문 분석 방법은 Function 개체를 사용하는 것입니다. 일반적인 응용 프로그램은 JQUERY의 AJAX 메서드에서 성공과 같은 반환된 데이터를 구문 분석하는 것입니다.

var json='{"name": "CJ" ,"나이":18}';

data =(new Function("","return " json))();


이때 데이터는 json 객체로 파싱될 json 객체입니다

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