- JavaScript:Moving to ES2015
- Ved Antani Simon Timms Narayan Prusty
- 197字
- 2021-07-09 19:07:40
Shims or polyfills
Polyfills (also known as shims) are patterns to define behavior from a new version in a compatible form supported by an older version of the environment. There's a great collection of ES6 shims called ES6 shim (https://github.com/paulmillr/es6-shim/); I would highly recommend a study of these shims. From the ES6 shim collection, consider the following example of a shim.
The Number.isFinite()
method of the ECMAScript 2015 (ES6) standard determines whether the passed value is a finite number. The equivalent shim for it would look something as follows:
var numberIsFinite = Number.isFinite || function isFinite(value) { return typeof value === 'number' && globalIsFinite(value); };
The shim first checks if the Number.isFinite()
method is available; if not, it fills it up with an implementation. This is a pretty nifty technique to fill in gaps in specifications. Shims are constantly upgraded with newer features and, hence, it is a sound strategy to keep the most updated shims in your project.
Note
The endsWith()
polyfill is described in detail at https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith. String.endsWith()
is part of ES6 but can be polyfilled easily for pre-ES6 environments.
Shims, however, cannot polyfill syntactical changes. For this, we can consider transpilers as an option.
- Django+Vue.js商城項目實戰
- OpenDaylight Cookbook
- PWA入門與實踐
- Java 9 Concurrency Cookbook(Second Edition)
- 造個小程序:與微信一起干件正經事兒
- Vue.js入門與商城開發實戰
- Microsoft Dynamics GP 2013 Reporting, Second Edition
- 量化金融R語言高級教程
- 零基礎學Python網絡爬蟲案例實戰全流程詳解(入門與提高篇)
- 精通Python自動化編程
- 蘋果的產品設計之道:創建優秀產品、服務和用戶體驗的七個原則
- HTML5開發精要與實例詳解
- Mastering Gephi Network Visualization
- 青少年學Python(第2冊)
- SaaS攻略:入門、實戰與進階