io.js benytter en moderne versjon av V8. Ved å holde prosjektet oppdatert med de siste versjonene av V8 sørger vi for at nye funksjoner fra JavaScript ECMA-262 spesifikasjonen er tilgjengelig for io.js utviklere innen rimelig tid. I tillegg vil sikkerhets- og ytelesesforbedringer komme raskt.
Versjon {{project.current_version}} av io.js kommer med V8 versjon {{project.current_v8}}, denne inkluderer ES6-funksjoner godt forbi versjon 3.28.73 som vil bli levert med Node.js™ 0.12.x.
Med Node.js™@0.12.x (V8 3.28+) aktiverte --harmony-flagget ES6-funksjonene
completed, staged og in progress (med unntak av proxies som ble
skjult ved bruk av --harmony-proxies). Dette resulterte i at ustabile, eller
til og med ødelagte, funksjoner som Arrow
Functions
var like tilgjengelig for utviklere som
generators,
som hadde veldig få, eller ingen, kjente problemer. Følgelig var det sikrest å
aktivere enten et fåtall funksjoner ved å bruke spesifikke harmony-flagg
(f.eks. --harmony-generators), eller aktivere dem alle og deretter bare
bruke en begrenset delmengde.
Med io.js@1.x (V8 4.1+) forsvinner all denne kompleksiteten. Alle harmony-funksjoner er nå logisk fordelt inn i tre grupper for shipping-, staged- og in progress-funksjoner:
-
Alle shipping-funksjoner, som V8 har vurdert som stabile, for eksempel generators, templates, new string methods og mange flere er nå skrudd på som standard i io.js og krever INGEN flagg.
-
Deretter er det staged-funksjoner, som er nesten fullførte funksjoner som ikke har blitt fullstendig testet eller oppdatert i henhold til den siste spesifikasjonen enda. Følgelig er de ikke ansett som stabile av V8 laget (f.eks. kan det være noen 'edge cases' som ikke har blitt oppdaget). Dette er mest sannsynlig ekvivalent med tilstanden til generators i 3.26. Disse er "bruk på egen risiko" funksjoner som nå krever flagget :
--es_staging(eller synonymet,--harmony). -
Til slutt, alle in progress-funksjoner kan bli aktivert individuelt av deres respektive harmony-flagg (f.eks.
--harmony_arrow_functions), selv om dette ikke er anbefalt med mindre det brukes til testing.
Fra og med v8 3.31.74.1, er block-scoped declarations forsettlig implementert med en ikke-kompatibel begrensning til strict modus kode. Utviklere bør være klar over at dette vil endres i takt med V8 sin implementasjon av ES6-spesifikasjonen.
-
Collections
Du kan se en mer detaljert liste med sammenligninger opp mot andre motorer på prosjektsiden til (https://kangax.github.io/compat-table/es6/)[compat-table].
-
Classes (strict mode only)
-
[Object literal extensions(https://github.com/lukehoban/es6features#enhanced-object-literals)]
-
Symbol.toStringTag(user-definable results forObject.prototype.toString)
New features are constantly being added to the V8 engine. Generally speaking, expect them to land on a future io.js release, although timing is unknown.
You may list all the in progress features available on each io.js release by grepping through the --v8-options argument. Please note that these are incomplete and possibly broken features of V8, so use them at your own risk:
iojs --v8-options | grep "in progress"Den nåværende oppførselen til --harmony-flagget i io.js er å kun aktivere
staged-funksjoner. Dette er tross alt nå synonymt med --es_staging. Som
nevnt ovenfor er dette fullførte funksjoner som enda ikke er ansett som stabile
enda. Hvis du ønsker å være på den sikre siden, kanskje spesielt med tanke på
produksjonsmiljøer, bør du vurdere å fjerne dette flagget inntil det leveres
som standard av V8 og io.js. Hvis du fortsetter å ha flagget aktivert bør du
være forberedt på at nyere io.js-oppgraderinger kan ødelegge koden din dersom
V8 endrer semantikken sin til å være mer lik standarden.
io.js har en enkel måte å liste alle avhengigheter/dependencies og versjoner av
en gitt binær med det globale objektet process. For å finne-V8 versjonen kan
du skrive følgende i terminalen:
iojs -p process.versions.v8