먼저 eval의 사용법에 대해 이야기해 보겠습니다. 내용이 익숙하신 분은 건너뛰셔도 됩니다.
eval 함수는 s가 문자열이 아닌 경우 s를 직접 반환합니다. . 그렇지 않으면 s 문을 실행합니다. s 문의 실행 결과가 값이면 이 값을 반환하고, 그렇지 않으면 정의되지 않은 값을 반환합니다. 객체 선언 구문 "{}"은 값을 반환할 수 없다는 점에 유의하는 것이 중요합니다. 값을 반환하려면 간단한 예를 들면 다음과 같습니다.
보시다시피 객체 선언문은 실행만 되고 값을 반환할 수 없습니다.
"{}"와 같이 일반적으로 사용되는 객체 선언문을 반환하려면 해당 값을 반환하기 전에 괄호로 묶어 표현식으로 변환해야 합니다. 이는 Ajax 개발에 JSON을 사용하는 기본 원칙 중 하나이기도 합니다. 두 번째 경고 문은 정의되지 않음을 출력하고, 괄호를 추가한 후 세 번째 경고 문은 문이 나타내는 개체를 출력하는 것을 예제에서 명확하게 볼 수 있습니다.
이제 이 글의 초점인 함수 내에서 전역 코드를 실행하는 방법에 대해 이야기해 보겠습니다. 이 문제를 설명하기 위해 예를 살펴보겠습니다.
이해하기 쉽습니다. 위의 데모1 함수는 지역 변수 s를 정의하는 function deco1(){var s='local';}과 동일합니다.
그러므로 최종 출력이 전역 변수라는 것은 놀라운 일이 아닙니다. 결국 모든 사람이 지역 변수와 전역 변수를 명확하게 구분할 수 있습니다.
자세히 경험해 보면 eval 함수의 특징을 알 수 있습니다. 이는 항상 호출되는 컨텍스트 변수 공간(패키지, 클로저라고도 함) 내에서 실행됩니다. 이는 변수 정의이든 마찬가지입니다. 또는 함수 정의이므로 다음과 같습니다. 코드에서 정의되지 않은 함수 오류가 발생합니다.
테스트 함수가 로컬 공간에 정의되어 있어 데모2 함수 내에서는 접근이 가능하지만 외부에서는 접근이 불가능하기 때문입니다.
공유: JS의 eval을 사용하여 JSON을 구문 분석할 때 주의할 점
JS에서 JSON 문자열을 JSON 데이터 형식으로 구문 분석하는 방법에는 일반적으로 두 가지가 있습니다.
1. 하나는 eval() 함수를 사용하는 것입니다.
2. 함수 개체를 사용하여 반환 분석을 수행합니다.
eval 함수를 사용하여 구문 분석하고 jquery의 각 메서드를 사용하여 순회합니다.
jquery를 사용하여 JSON 데이터를 구문 분석합니다. jquery 요청 후 반환되는 결과는 json 개체입니다. 여기서 고려되는 것은 플러그를 사용하여 서버에서 반환하는 문자열 형식입니다. - JSONObject와 같은 기능 JSON 객체도 이와 비슷하므로 여기서는 설명하지 않겠습니다.
여기서 먼저 JSON 문자열 세트가 제공됩니다. 문자열 세트는 다음과 같습니다.
jquery에서 비동기적으로 얻은 데이터 유형인 json 개체와 문자열을 기반으로 두 가지 방법으로 얻은 결과를 처리하는 방법을 소개합니다.
1. 서버에서 반환된 JSON 문자열의 경우 jquery 비동기 요청에 유형 설명이 없거나 문자열로 허용되는 경우 메서드가 너무 번거롭지 않아야 합니다. eval()에 문자열을 넣으면 한 번 실행됩니다. 이 방법은 일반적인 javascipt를 사용하여 json 객체를 얻는 데에도 적합합니다. 다음은 예입니다.
var dataObj=eval("(" data ")");//json 객체로 변환
평가에 "("(" data ")");//"를 추가해야 하는 이유는 무엇인가요?
이유는 평가 자체의 문제입니다. json은 "{}"으로 시작하고 끝나기 때문에 JS에서는 명령문 블록으로 처리되므로 강제로 표현식으로 변환해야 합니다.
괄호를 추가하는 목적은 JavaScript 코드 처리 시 괄호 안의 표현식을 명령문으로 실행하는 대신 eval 함수가 객체로 변환하도록 강제하기 위한 것입니다. 예를 들어 객체 리터럴 {}이 외부 대괄호와 함께 추가되지 않은 경우 eval은 중괄호를 JavaScript 코드 블록의 시작 및 끝 표시로 인식하고 {}는 빈 문을 실행하는 것으로 간주됩니다. 따라서 다음 두 가지 실행 결과는 다릅니다.
이런 글은 JS 어디에서나 볼 수 있습니다.
예: (function()) {}();
2. 서버에서 반환된 JSON 문자열의 경우 jquery 비동기 요청이 유형(일반적으로 이 구성 속성)을 "json"으로 설정하거나 $.getJSON() 메서드를 사용하여 서버 반환을 얻는 경우 이때 얻은 결과는 이미 json 개체이므로 eval() 메서드가 필요하지 않으며 개체를 직접 호출하기만 하면 됩니다. 여기서는 데이터 처리 방법을 설명하기 위해 $.getJSON 메서드를 예로 사용합니다.
두 번째 구문 분석 방법은 Function 개체를 사용하는 것입니다. 일반적인 응용 프로그램은 JQUERY의 AJAX 메서드에서 성공과 같은 반환된 데이터를 구문 분석하는 것입니다.