JSON and JSONP
JSON (JavaScript Object Notation) is a lightweight data exchange format used to exchange information between browsers and servers.
JSONP (JSON With Padding) is JSON (or wrapped JSON) packaged in a function call.
JSON is a data format, and JSONP is a data calling method.
For security reasons, scripts (AJAX) cannot access content outside this domain. However, static resources are not restricted by domain policies and can load scripts, styles, pictures and other static resources from any domain. JSOP uses this principle to achieve cross-domain data acquisition.
Example 1:
This example shows how to call a JavaScript function with static JSON data as a parameter.
Example 2:
The first function call can be written in a js file and placed on the server, loaded into the page using a script tag, and this tag can be created dynamically.
The content of remote.js is the same as what was written in the tag before:
1 showPrice({symbol: 'IBM', price: 91.42});
The dynamically inserted JavaScript code takes the JSON data to be passed as a parameter and the parameter of the showPrice function calling statement.
So the question is, should the showPrice function be called every time the data is obtained? This requires the front-end and back-end programmers to make an agreement. Of course, this will cause a lot of inconvenience, especially when the interface is open to public development. JSOP is processed in this way: the front end is supported to pass a callback function name parameter, the back end receives the callback function name parameter, and then generates a call to the function, passes the JSON data as a parameter, and inserts it into the page when it reaches the client to start execution.
Example 3:
Dynamically insert code with callback parameters:
Code snippet of JSONP service implemented in PHP on the backend: