在学习和使用 JavaScript 的时候,咱们会常常碰到两个术语:shim 和 polyfill。它们有许多定义和解释,意思相近又有差别。浏览器
Shim
Shim 指的是在一个旧的环境中模拟出一个新 API ,并且仅靠旧环境中已有的手段实现,以便全部的浏览器具备相同的行为。主要特征:学习
- 该 API 存在于现代浏览器中;
- 浏览器有各自的 API 或 可经过别的 API 实现;
- API 的全部方法都被从新实现;
- 拦截 API 调用,并提供本身的实现;
- 是一个优雅降级。
Polyfill
polyfill 是一段代码(或者插件),提供了那些开发者们但愿浏览器原生提供支持的功能。程序库先检查浏览器是否支持某个API,若是不支持则加载对应的 polyfill。主要特征:spa
- 是一个浏览器 API 的 Shim;
- 与浏览器有关;
- 没有提供新的API,只是在 API 中实现缺乏的功能;
- 以只须要引入 polyfill ,它会静静地工做;
shim 的概念要比 polyfill 更大一些,能够将 polyfill 理解为专门兼容浏览器 API 的 shim 。简单的说,若是浏览器X支持标准规定的功能,那么 polyfill 能够让浏览器 Y 的行为与浏览器 X 同样。插件