$. ajax 와 $. post, $. get 무시 하기 쉬 운 차이 점

1650 단어 js기초 js
차이: 되 돌아 오 는 반전 함수, 매개 변수 유형 이 다 릅 니 다.
$.ajax({
        //          
        type: "POST",//    
        dataType: "json",//            
        url: url,//demo
        data: params,
        success: function (result) {
       alert(result.message);
        },
        error: function (result) {
            if (result) {
                alert(result.message);
            } else {
                alert("    ,      !");
            }
        }
    });

$.post
$.post('changeReportStatus', $('#showInputForm').serialize(), function (data) {
        var result =  JSON.parse(data);//**    JSON  **
        alert(result.message);
    });

되 돌아 오 는 데 이 터 를 JSON 대상 으로 수 동 으로 변환 해 야 합 니 다.
변환 방법 은 다음 과 같 습 니 다.
var str = {'success':true,'message':'  '};
//1.   
var obj = eval('(' + str + ')');
//2.   
var obj = str.parseJSON(); // JSON      JSON  
//3.   
var obj = JSON.parse(str); // JSON      JSON  
//   
Alert(obj.success);
Alert(obj.message);


특히 주의: 만약 에 obj 가 원래 JSON 대상 이 라면 eval () 함 수 를 사용 하여 변환 한 후 (여러 번 변환 하 더 라 도) JSON 대상 이지 만 parseJSON () 함 수 를 사용 하여 처리 하면 문제 가 발생 할 수 있 습 니 다 (문법 이상 을 던 집 니 다).
버 전 문제 주의: 위의 몇 가지 방법 중 eval () 함수 가 js 자체 가 가지 고 있 는 것 을 제외 하고 다른 몇 가지 방법 은 모두 json. js 가방 에서 나 왔 습 니 다.새 버 전의 JSON 은 API 를 수정 해 JSON. stringify () 와 JSON. parse () 두 가지 방법 을 모두 자 바스 크 립 트 의 내장 대상 에 주입 했다. 전 자 는 Object. toJSONstring () 이 되 었 고 후 자 는 String. parseJSON () 이 되 었 다.toJSONstring () 과 parseJSON () 방법 을 찾 지 못 하면 json 패키지 버 전이 너무 낮 다 는 것 을 설명 합 니 다.

좋은 웹페이지 즐겨찾기