The fetch API has obvious advantages over traditional XHR, where the design is overly complex:

const request = new XMLHttpRequest() request.responseType = 'json' request.open('GET', '/url', true) request.onload = () => { console.log(request.response) } request.onerror = () => { console.log('shits happen! ') } request.send(null)Copy the code

Fetch, on the other hand, uses the already popular Promise API:

fetch('/url').then(res => {}).catch(err => {})
Copy the code

One interesting point is that the polyfills of fetch in the browser are implemented using XHR, whereas in the latest spec XHR is implemented using FETCH, which means fetch is lower level than XHR despite having a more elegant API design

Why is fetch used in Node.js?

Most HTTP modules in Node.js provide large and complete functions, such as Request and superAgent, while Node-Fetch can be said to be one of the lightest, without excessive design. Got.

Another thing worth mentioning is that using a consistent API in different JavaScript environments makes for a much better development experience, not to mention using the fetch API which is so elegantly designed 🙂

For cross-runtime applications, isomorphic-Fetch can take care of both node and Browser environment.

MDN: Fetch API – Web APIs