W jQuery dla $.ajax() wywołania zwrotne (Callback Function) są w następującej kolejności:
- beforeSend callback option is invoked; it receives the jqXHR object and the settings object as parameters.
- error callback option is invoked, if the request fails. It receives the jqXHR, a string indicating the error type, and an exception object if applicable. Some built-in errors will provide a string as the exception object: "abort", "timeout", "No Transport".
- dataFilter callback option is invoked immediately upon successful receipt of response data. It receives the returned data and the value of dataType, and must return the (possibly altered) data to pass on to success.
- success callback option is invoked, if the request succeeds. It receives the returned data, a string containing the success code, and the jqXHR object.
- promise callbacks — .done(), .fail(), .always(), and .then() — are invoked, in the order they are registered.
- complete callback option fires, when the request finishes, whether in failure or success. It receives the jqXHR object, as well as a string containing the success or error code.
function getLatest() {
$.ajax({
url: "https://www.instagram.com/" + settings.instagram_profile + "?__a=1",
type: "get",
success: function(result) {
let temp = result.graphql.user.edge_owner_to_timeline_media.edges[result.graphql.user.edge_owner_to_timeline_media.edges.length - 1];
let post = {
image_description: temp.node.edge_media_to_caption.edges[0].node.text,
image_url: temp.node.display_url,
image_upload_date: new Date(temp.node.taken_at_timestamp * 1000)
};
return post;
}
});
}
z użyciem .done() - link
function getLatest() {
$.ajax({
url: "https://www.instagram.com/" + settings.instagram_profile + "?__a=1",
type: "get",
})
.done(function(result) {
// console.log(result);
let temp = result.graphql.user.edge_owner_to_timeline_media.edges[result.graphql.user.edge_owner_to_timeline_media.edges.length - 1];
let post = {
image_description: temp.node.edge_media_to_caption.edges[0].node.text,
image_url: temp.node.display_url,
image_upload_date: new Date(temp.node.taken_at_timestamp * 1000)
};
return post;
});
}