>웹 프론트엔드 >JS 튜토리얼 >JavaScript 변환 및 JSON 메소드 파싱에 대한 자세한 설명 example_javascript 기술

JavaScript 변환 및 JSON 메소드 파싱에 대한 자세한 설명 example_javascript 기술

WBOY
WBOY원래의
2016-05-16 15:30:101428검색

이 문서의 예에서는 JavaScript 변환 및 JSON 메서드 구문 분석을 설명합니다. 참고하실 수 있도록 모든 사람과 공유하세요. 자세한 내용은 다음과 같습니다.

json 형식의 데이터는 다음과 같습니다.

var json = { 'jquery': [{ "id": "1", "type": "ASP.NET", "title": "JSON全解析"}] }
    alert(json.jquery[0].id);
    alert(json.jquery[0].type);
    alert(json.jquery[0].title);

Javascript는 json 데이터를 구문 분석합니다.

window.onload = function() {
 var json = { "China": "[{'City':'上海','value':'1'},{'City':'南京','value':'2'},{'City':'杭州','value':'3'},{'City':'武汉','value':'4'}]" }
 var datas = eval(json.China);
 for (var i = 0; i < datas.length; i++) 
 {
  alert(datas[i].City);
  alert(datas[i].value);
 }
}

보충: jQuery 파싱 json 메서드:

eval 함수를 사용하여 파싱하고 jquery의 각 메서드를 탐색합니다.

JQuery를 사용하여 JSON 데이터를 구문 분석합니다. JQuery 요청 후 반환되는 결과는 JSON 형식으로 서버에서 반환되는 문자열 형식입니다. JSONObject와 같은 플러그인 JSON 객체도 이와 유사하므로 여기서는 설명하지 않겠습니다.

여기서 먼저 JSON 문자열 세트가 제공됩니다. 문자열 세트는 다음과 같습니다.

var data=" 
{ 
root: 
[ 
  {name:'1',value:'0'}, 
  {name:'6101',value:'北京市'}, 
  {name:'6102',value:'天津市'}, 
  {name:'6103',value:'上海市'}, 
  {name:'6104',value:'重庆市'}, 
]
}"; 

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

평가()

서버에서 반환한 JSON 문자열에 대해 jquery 비동기 요청이 유형을 지정하지 않거나 문자열 모드로 허용하는 경우에는 이를 객관화해야 하거나 문자열을 넣는 것입니다. eval()에서 한 번 실행됩니다. 이 방법은 일반적인 javascipt를 사용하여 json 객체를 얻는 데에도 적합합니다. 다음은 예입니다.

// 转换为json对象
var dataObj=eval("("+data+")");

여기서 평가에 ("(" data ")")를 추가해야 하는 이유는 무엇입니까?

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

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

// return undefined
alert(eval("{}"); 
// return object[Object]
alert(eval("({})");

이런 글은 JS 어디에서나 볼 수 있습니다. 예를 들어: (function()) {}();

//输出root的子对象数量 
alert(dataObj.root.length);
$.each(dataObj.root,fucntion(idx,item){ 
  if(idx==0){ 
    return true; 
  } 
  //输出每个root子对象的名称和值 
  alert("name:"+item.name+",value:"+item.value); 
}) 

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

서버에서 반환된 JSON 문자열

서버에서 반환된 JSON 문자열의 경우 jquery 비동기 요청이 유형(일반적으로 이 구성 속성)을 "json"으로 설정하거나 $.getJSON() 메서드를 사용하여 서버 반환을 얻는 경우 eval( ) 메소드는 필요하지 않습니다. 이때 얻은 결과는 이미 json 객체이므로 해당 객체를 직접 호출하기만 하면 됩니다. 여기서는 데이터 처리 방법을 설명하기 위해 $.getJSON 메소드를 예로 사용합니다.

$.getJSON("http://www.xxxx.com/",{param:"gaoyusi"},function(data){ 
  //此处返回的data已经是json对象 
  //以下其他操作同第一种情况 
  $.each(data.root,function(idx,item){ 
    if(idx==0){ 
      //同countinue,返回false同break 
      return true;
    } 
    alert("name:"+item.name+",value:"+item.value); 
  }); 
}); 

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

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

var json='{"name":"CJ","age":18}';
data =(new Function("","return "+json))();

이때의 데이터는 파싱할 json 객체입니다.

이 기사가 JavaScript 프로그래밍에 종사하는 모든 사람에게 도움이 되기를 바랍니다.

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