Potrzebuję wysłać dane JSON do adresu URL i przetworzyć odpowiedź, która jest również danymi JSON. Jak mogę to zrobić za pomocą vanilla javascript, tzn. Bez bibliotek innych firm? Muszę również ustawić nagłówki żądań. Czy ktoś mógłby mi podać przykład, jak to zrobić?Jak wykonać żądanie AJAX, aby opublikować dane JSON i przetworzyć odpowiedź?
6
A
Odpowiedz
13
OK Oto jak zrobić zarówno GET i POST w wanilii JavaScript, tj żadnych zewnętrznych bibliotek jak jQuery, w tym jak ustawić żądania nagłówki:
// Just to namespace our functions and avoid collisions
var _SU3 = _SU3 ? _SU3 : new Object();
// Does a get request
// url: the url to GET
// callback: the function to call on server response. The callback function takes a
// single arg, the response text.
_SU3.ajax = function(url, callback){
var ajaxRequest = _SU3.getAjaxRequest(callback);
ajaxRequest.open("GET", url, true);
ajaxRequest.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
ajaxRequest.send(null);
};
// Does a post request
// callback: the function to call on server response. The callback function takes a
// single arg, the response text.
// url: the url to post to
// data: the json obj to post
_SU3.postAjax = function(url, callback, data) {
var ajaxRequest = _SU3.getAjaxRequest(callback);
ajaxRequest.open("POST", url, true);
ajaxRequest.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
ajaxRequest.setRequestHeader("Connection", "close");
ajaxRequest.send("data=" + encodeURIComponent(data));
};
// Returns an AJAX request obj
_SU3.getAjaxRequest = function(callback) {
var ajaxRequest;
try {
ajaxRequest = new XMLHttpRequest();
} catch (e) {
try {
ajaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
ajaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e){
return null;
}
}
}
ajaxRequest.onreadystatechange = function() {
if (ajaxRequest.readyState == 4) {
// Prob want to do some error or response checking, but for
// this example just pass the responseText to our callback function
callback(ajaxRequest.responseText);
}
};
return ajaxRequest;
};
używać go tak:
function processResponse(responseText) {
// Response text is a json:
var obj = JSON.parse(responseText) // won't work all browsers, there are alternatives
// Do something with obj
....
}
var jsonToPost = .... // whatever your json is
var url = ... // the URL to post to
_SU3.postAjax(url, processResponse, jsonToPost);
Nie sądzę, że byłbyś w stanie uzyskać dane json, chyba że dane są wysyłane przez serwer jako json_encoded –
zobacz moją odpowiedź, powinien zrobić to, co chcesz –