java-script:ajax-fetch
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
java-script:ajax-fetch [2023/08/03 13:39] – odefta | java-script:ajax-fetch [2023/08/03 16:33] (current) – odefta | ||
---|---|---|---|
Line 7: | Line 7: | ||
===== AJAX using the fetch API in JavaScript (Web Browser) ===== | ===== AJAX using the fetch API in JavaScript (Web Browser) ===== | ||
- | This code sends a GET request to ' | + | This code sends a GET request to ' |
<code javascript ajax-fetch.html> | <code javascript ajax-fetch.html> | ||
Line 34: | Line 34: | ||
</ | </ | ||
- | The following script will display the data in the web page (instead of console) and format it a bit: | + | The following script will display the data in a much more cleaner way and also display the avatar image content: |
<code javascript ajax-fetch-format.html> | <code javascript ajax-fetch-format.html> | ||
Line 75: | Line 75: | ||
</ | </ | ||
+ | |||
+ | To run it, just double click on the html file, it will be opened in the web browser. | ||
===== AJAX using the fetch API in JavaScript (Node.js) ===== | ===== AJAX using the fetch API in JavaScript (Node.js) ===== | ||
Line 94: | Line 96: | ||
</ | </ | ||
- | The the script should be adapted for node.js: | + | Then the script should be adapted for node.js: |
<code javascript ajax-fetch-node.js> | <code javascript ajax-fetch-node.js> | ||
Line 134: | Line 136: | ||
node ajax-fetch-node.js | node ajax-fetch-node.js | ||
</ | </ | ||
+ | |||
+ | ===== Using XMLHttpRequest (the traditional AJAX method) to fetch data from a server ===== | ||
+ | |||
+ | We use the **XMLHttpRequest** object to send a GET request to the GitHub API, just like we did with Fetch API above. We then use the onload event handler to process the response when it's ready. If the request is successful (status code 200), we parse the response text as JSON, and then create some HTML content that displays the user's name, avatar, and url. If the request fails, we log the response text to the console. | ||
+ | |||
+ | Finally, we call the loadUsers function to kick off the AJAX request when the script loads. | ||
+ | |||
+ | This will fetch data from the server without a page reload, in true AJAX style! | ||
+ | |||
+ | <code javascript fetch-true-ajax-style.html> | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | |||
+ | <div id=" | ||
+ | |||
+ | < | ||
+ | function loadUsers() { | ||
+ | var xhr = new XMLHttpRequest(); | ||
+ | xhr.open(" | ||
+ | xhr.onload = function () { | ||
+ | if (xhr.readyState == 4 && xhr.status == " | ||
+ | var users = JSON.parse(xhr.responseText); | ||
+ | var html = ''; | ||
+ | for(var user of users){ | ||
+ | html += `< | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | } | ||
+ | document.getElementById(' | ||
+ | } else { | ||
+ | console.error(xhr.responseText); | ||
+ | } | ||
+ | } | ||
+ | xhr.send(); | ||
+ | } | ||
+ | |||
+ | loadUsers(); | ||
+ | |||
+ | </ | ||
+ | |||
+ | </ | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | <note tip> | ||
+ | Node.js can certainly make HTTP requests to APIs or other servers using libraries like axios or node-fetch, or using built-in modules like http or https. These requests are indeed asynchronous, | ||
+ | While both AJAX in the browser and HTTP requests in Node.js involve asynchronous operations, they' | ||
+ | </ | ||
+ |
java-script/ajax-fetch.1691059192.txt.gz · Last modified: 2023/08/03 13:39 by odefta