苏溪云
Gist-ES6-Fetch-Usage

Introduction

Do you prefer the usage of "ES6 Promise"? If you do, you will like the usage of "Fetch" too.
Compared to "Ajax", "Fetch" owns a competitive feature: promise, which synchronize asynchronous methods elegantly, the meaning and the usage of "Fetch" can be understood easily as well.
Here, I'd like to list the most common usage of "Fetch".

Flow

The flow of fetching stuff is simple:

Usage

Fetch once

Suppose we would fetch the content of an remote html

fetch('./data/test.html')
    .then(function (response) {
        return response.text()    // return a promise 
    })
    .then(function (body) {
        console.log( body )    // log: html content
    })

Fetch data right after the other data fetched(Chain)

If we'd like to fetch data(json) right after fetching content(html)

fetch('./data/test.html')
    .then(response => {
        return response.text()
    })
    .then(body => {
        console.log(body)
        return fetch('./data/test.json')  // return a promise(`fetch('/url')` will return a promise ) 
    })
    .then(response => {
        return response.json()  // return a promise too
    })
    .then(json => {
        console.log(json)  // log: json's data
    })

Complete all fetching action

Promise.all([
    Promise.resolve(fetch('./data/test.html')),
    Promise.resolve(fetch('./data/test.json'))
]).then(data => {
    console.log('Two requests are both completed!')
})

API

Github Fetch Document
Offcial Manual

Conclusion

Fetch, well done!

感谢你的阅读。欢迎通过微信(扫描下方二维码)或Github订阅我的博客。

微信公众号:苏溪云的博客

发布时间: 8/8/2017
分类: 技术/前端/JavaScript
作者版权所有,转载请注明出处,禁止商业转载