Explain how JSONP works (and how it's not really Ajax)
JSONP (JSON with Padding) is a method commonly used to bypass the cross-domain policies in web browsers because Ajax requests from the current page to a cross-origin domain is not allowed.
JSONP works by making a request to a cross-origin domain via a <script>
tag and usually with a callback
query parameter, for example: https://example.com?callback=printData
. The server will then wrap the data within a function called printData
and return it to the client.
<!-- https://mydomain.com --><script>function printData(data) {console.log(`My name is ${data.name}!`);}</script><script src="https://example.com?callback=printData"></script>
// File loaded from https://example.com?callback=printDataprintData({ name: 'John Doe' });
The client has to have the printData
function in its global scope and the function will be executed by the client when the response from the cross-origin domain is received.
JSONP can be unsafe and has some security implications. As JSONP is really JavaScript, it can do everything else JavaScript can do, so you need to trust the provider of the JSONP data.
These days, CORS is the recommended approach and JSONP is seen as a hack.