-
Notifications
You must be signed in to change notification settings - Fork 1
The state of ES6 on io.js
io.js is built against modern versions of V8. By keeping up-to-date with the latest releases of this engine, we ensure new features from the JavaScript ECMA-262 specification are brought to io.js developers in a timely manner, as well as continued performance and stability improvements.
Version 1.0.0 of io.js ships with V8 3.31.71.4, well beyond version 3.26.33 that will be shipped with joyent/[email protected]. Due to the advancements in the V8 engine regarding ES >= 5 ("harmony") features, harmony runtime flags have been completely refactored on recent versions of V8 to accommodate this new reality.
On joyent/[email protected] (V8 3.26), the --harmony
runtime flag enabled all completed, staged and in progress ES6 features together, in bulk (with the exception of nonstandard/non-harmonious semantics for typeof
which were hidden under --harmony-typeof
). This meant that some really buggy or even broken features like proxies were just as readily available for developers as generators, which had very little or even no known-issues. As such, it was best practice to either enable only certain features by using specific runtime harmony feature flags (e.g. --harmony-generators
), or simply enable all of them and then use a restricted subset.
With [email protected] (V8 3.31+), all that complexity goes away. All harmony features are now logically split into three groups for shipping, staged and in progress features:
- All shipping features, the ones that V8 has considered stable, like generators, templates, new string methods and many others are turned on by default on io.js and do NOT require any kind of runtime flag.
- Then there are staged features which are almost-completed features that haven't been completely tested or updated to the latest spec yet and therefore are not considered stable by the V8 team (e.g. there might be some edge cases left to discover). This is probably the equivalent of the state of generators on 3.26. These are the "use at your own risk" type of features that now require a runtime flag:
--es_staging
(or its synonym,--harmony
). - Finally, all in progress features can be activated individually by their respective harmony flag (e.g.
--harmony_arrow_functions
), although this is highly discouraged unless for testing purposes.
- Block scoping (
let
,const
, andfunction
-in-blocks) (strict mode only) - Collections
- Generators
- Binary and octal literals
- Promises
- New String methods
- Symbols
- Template literals
You can view a more detailed list, including a comparison with other engines, on the compat-table project page.
- Classes (strict mode only)
- Object literal extensions
-
Symbol.toStringTag
(user-definable results forObject.prototype.toString
)
The current behaviour of the --harmony
flag on io.js is to enable staged features only. After all, it is now a synonym of --es_staging
. As mentioned above, these are completed features that have not been considered stable yet. If you want to play safe, especially on production environments, consider removing this runtime flag until it ships by default on V8 and, consequently, on io.js. If you keep this enabled, you should be prepared for further io.js upgrades to break your code if V8 changes their semantics to more closely follow the standard.
io.js provides a simple way to list all dependencies and respective versions that ship with a specific binary through the process
global object. In case of the V8 engine, type the following in your terminal to retrieve its version:
iojs -e 'console.log(process.versions.v8)'
E.g. output: 3.31.71.4
.
A formal plan has not been discussed yet but the TC is looking into regular updates, especially if there are no breaking changes from V8's API.