Provides compatibility shims so that legacy JavaScript engines behave as closely as possible to ECMAScript 6 (Harmony).
HTML version of the final ECMAScript 6 spec
If you want to use it in browser:
- Just include es6-shim before your scripts.
- Include es5-shim especially if your browser doesn't support ECMAScript 5 - but every JS engine requires the
es5-shim
to correct broken implementations, so it's strongly recommended to always include it.
For node.js
, io.js
, or any npm
-managed workflow (this is the recommended method):
npm install es6-shim
Alternative methods:
component install paulmillr/es6-shim
if you’re using component(1).bower install es6-shim
if you’re using Bower.
In both browser and node you may also want to include unorm
; see the String.prototype.normalize
section for details.
Map
,Set
(requires ES5 property descriptor support)Promise
String
:fromCodePoint()
(a standalone shim is also available)raw()
String.prototype
:codePointAt()
(a standalone shim is also available)endsWith()
(a standalone shim is also available)includes()
(a standalone shim is also available)repeat()
(a standalone shim is also available)startsWith()
(a standalone shim is also available)
RegExp
:new RegExp
, when given a RegExp as the pattern, will no longer throw when given a "flags" string argument. (requires ES5)
RegExp.prototype
:flags
(requires ES5) (a standalone shim is also available)
Number
:EPSILON
MAX_SAFE_INTEGER
MIN_SAFE_INTEGER
isNaN()
(a standalone shim is also available)isInteger()
isSafeInteger()
isFinite()
parseInt()
parseFloat()
Array
:Array.prototype
:copyWithin()
entries()
fill()
find()
(a standalone shim is also available)findIndex()
(a standalone shim is also available)keys()
(note: keys/values/entries return anArrayIterator
object)values()
Object
:assign()
(a standalone shim is also available)is()
(a standalone shim is also available)keys()
(in ES5, but no longer throws on non-object non-null/undefined values in ES6)setPrototypeOf()
(IE >= 11)
Math
:acosh()
asinh()
atanh()
cbrt()
clz32()
cosh()
expm1()
fround()
hypot()
imul()
log10()
log1p()
log2()
sign()
sinh()
tanh()
trunc()
Math functions’ accuracy is 1e-11.
-
Reflect
apply()
construct()
defineProperty()
deleteProperty()
enumerate()
get()
getOwnPropertyDescriptor()
getPrototypeOf()
has()
isExtensible()
ownKeys()
preventExtensions()
set()
setPrototypeOf()
-
String.prototype
Annex B HTML methods These methods are part of "Annex B", which means that although they are a defacto standard, you shouldn't use them. None the less, thees6-shim
provides them:anchor()
big()
blink()
bold()
fixed()
fontcolor()
fontsize()
italics()
link()
small()
strike()
sub()
sup()
The Map
, Set
, and Promise
implementations are subclassable.
You should use the following pattern to create a subclass in ES5 which will continue to work in ES6:
require('es6-shim');
function MyPromise(exec) {
var promise = new Promise(exec);
Object.setPrototypeOf(promise, MyPromise.prototype);
// ...
return promise;
}
Object.setPrototypeOf(MyPromise, Promise);
MyPromise.prototype = Object.create(Promise.prototype, {
constructor: { value: MyPromise }
});
Including a proper shim for String.prototype.normalize
would increase the size of this library by a factor of more than 4.
So instead we recommend that you install the unorm
package alongside es6-shim
if you need String.prototype.normalize
.
See paulmillr#134 for more discussion.
It is not possible to implement WeakMap in pure javascript.
The es6-collections implementation doesn't hold values strongly, which is critical for the collection. es6-shim
decided to not include an incorrect shim.
WeakMap
has very unusual use-cases, so you probably won't need it at all (use simple Map
instead).
var assert = require('assert');
require('es6-shim');
'abc'.startsWith('a'); // true
'abc'.endsWith('a'); // false
'john alice'.includes('john'); // true
'123'.repeat(2); // '123123'
Object.is(NaN, NaN); // Fixes ===. 0 isnt -0, NaN is NaN
Object.assign({a: 1}, {b: 2}); // {a: 1, b: 2}
Number.isNaN('123'); // false. Global isNaN('123') will give true.
Number.isFinite('asd'); // false. Global isFinite() will give true.
// Tests if value is a number, finite,
// >= -9007199254740992 && <= 9007199254740992 and floor(value) === value
Number.isInteger(2.4); // false.
Math.sign(400); // 1, 0 or -1 depending on sign. In this case 1.
[5, 10, 15, 10].find(function (item) { return item / 2 === 5; }); // 10
[5, 10, 15, 10].findIndex(function (item) { return item / 2 === 5; }); // 1
// Replacement for `{}` key-value storage.
// Keys can be anything.
var map = new Map([['Bob', 42], ['Foo', 'bar']]);
map.set('John', 25);
map.set('Alice', 400);
map.set(['meh'], 555);
assert(map.get(['meh']) === undefined); // undefined because you need to use exactly the same object.
map.delete('Alice');
map.keys();
map.values();
assert(map.size === 4);
// Useful for storing unique items.
var set = new Set([0, 1]);
set.add(2);
set.add(5);
assert(set.has(0) === true);
assert(set.has(1) === true);
assert(set.has(2) === true);
assert(set.has(4) === false);
set.delete(5);
// Promises, see
// http://www.slideshare.net/domenicdenicola/callbacks-promises-and-coroutines-oh-my-the-evolution-of-asynchronicity-in-javascript
// https://github.com/petkaantonov/bluebird/#what-are-promises-and-why-should-i-use-them
Promise.resolve(5).then(function (value) {
if (value) throw new Error("whoops!");
// do some stuff
return anotherPromise();
}).catch(function (e) {
// any errors thrown asynchronously end up here
});
Object.setPrototypeOf
/Reflect.setPrototypeOf
- Note that null objects (
Object.create(null)
, eg, an object withnull
as its[[Prototype]]
) can not have their[[Prototype]]
changed except via a nativeObject.setPrototypeOf
.
- Note that null objects (