Fetch 相对 XHR 来说具有简洁、易用、声明式、天生基于 Promise 等特点。XHR 使用方式复杂,接口繁多,最重要的一点个人觉得是它的回调设计,对于实现 try...catch 比较繁琐。

    但是 Fetch 也有它的不足,相对于 XHR 来说,目前它具有以下劣势:

    • 不能取消(虽然 AbortController 能实现,但是目前兼容性基本不能使用,可以使用 polyfill

    • 不能获取进度

    • 不能设置超时(可以通过简单的封装来模拟实现)

    • 兼容性目前比较差(可以使用 polyfill 间接使用 XHR 来优雅降级,这里推荐使用 isomorphic-fetch

    在了解 Fetch 和 XHR 的一些不同后,还是需要根据自身的业务需求来选择合适的技术,因为技术没有永远的好坏,只有合不合适。

    下面章节我们将介绍如何“优雅”的使用 Fetch 以及如何尽量避免掉劣势。