A JavaScript engine is a program or interpreter which executes JavaScript code. A JavaScript engine may be a traditional interpreter, or it may utilize just-in-time compilation to bytecode in some manner.[1] Although there are several uses for a JavaScript engine, it is most commonly used in Web browsers.[2][3][unreliable source?]
Before the second browser war in 2008-2009, JavaScript engines (also termed JavaScript interpreter or JavaScript implementation) were simply interpreters that read and executed JavaScript source code.
The first JavaScript engine was created by Brendan Eich at Netscape Communications Corporation for the Netscape Navigator web browser. The engine, code named SpiderMonkey, is implemented in C++. It has since been updated (in JavaScript 1.5) to conform to ECMA-262 Edition 3. The Rhino engine, created primarily by Norris Boyd (also at Netscape) is a JavaScript implementation in Java. Like SpiderMonkey, Rhino is ECMA-262 Edition 3 compliant. Applications of the technology include Apple Safari 4's Nitro, Google Chrome's V8 and Mozilla Firefox 3.5's TraceMonkey.
By far the most common host environment for JavaScript is a web browser. Web browsers typically use the public application programming interface (API) to create "host objects" responsible for reflecting the Document Object Model (DOM) into JavaScript.
—CNET[3]
A typical major browser has a graphical engine and an independent JavaScript engine, which allows for easier testing, reimplementation or use in other projects. For example, Carakan is used with Presto; Nitro with WebKit; SpiderMonkey with Gecko; KJS with KHTML; Rhino by default has no layout engine. Other combinations are possible, for example, V8 with Blink in Google Chrome. The JavaScript engine gives developers access to functionality (networking, DOM handling, external events, HTML5 video, canvas and data storage) needed to control the web browser.
During this period there was a race by browser developers to develop even faster JavaScript engines in response to the growing use of JavaScript frameworks and Ajax, as the user's experience is directly influenced by the browser's ability to execute the site's client-side code. Launched on 2 September 2008, Google Chrome was praised for its JavaScript performance, but other browsers soon received new JavaScript engines which were faster. Later, Chrome won in the races of better performance. Chrome's strength is its application performance and JavaScript processing speed, both of which were independently verified by multiple websites to be the fastest amongst the major browsers of its time.[4][5][6] With the advent of WebKit's Squirrelfish and Mozilla's TraceMonkey JavaScript virtual machines, Chrome's JavaScript execution performance had been found to be slower.[7][8][9][10] Google responded with the Danish-developed V8 which boosted JavaScript performance in Google Chrome 2.
On June 2, 2008, the WebKit development team announced SquirrelFish,[11] a then-new JavaScript engine that vastly improves Safari's speed at interpreting scripts.[12] The engine was one of the new features in Safari 4, released for developers on June 11, 2008; the final JavaScript engine was called Nitro.
In January 2009, the engine then known as SquirrelFish Extreme (SFX) was enabled for Mac OS X on x86-64 architectures as it passes all tests on that platform by Apple Inc.[13] Released June 30, 2009, Firefox 3.5 includes the optimization technique that offered "performance improvements ranging between 20 and 40 times faster" compared to Firefox 3 in some cases.[14]
In early 2010, the Norwegian Opera browser replaced the aging Futhark with the faster Carakan, which was 2.5 times faster in early testing.[3] Others in the race, at this time, include Apple's Safari's Nitro (the engine formerly known as SquirrelFish) and Firefox's new JägerMonkey (a "cross-child of Nitro with the older TraceMonkey Engine").[2] Microsoft lagged behind, lacking a dedicated JavaScript engine and being the slowest of the major browsers. Although by mid-2010, Microsoft held out the carrot of Chakra in then unreleased Internet Explorer 9.[2] JägerMonkey began testing in the publicly released Firefox 4.0 beta in Summer 2010.[15] Safari 5, also released in Summer 2010, featured 30 percent faster JavaScript performance than Safari 4 (using the Nitro engine).[16]
In 2011, Firefox 4 and Internet Explorer 9 were released with their JavaScript software.[citation needed]
JavaScript is a dialect of ECMAScript, which is supported in many applications, especially web browsers. Dialects sometimes include extensions to the language, or to the standard library and related application programming interfaces (API) such as the World Wide Web Consortium (W3C) specified Document Object Model (DOM). This means that an application written in one dialect may be incompatible with another, unless the applications are written to use only a common subset of supported features and APIs ("core").
A dialect and an implementation are distinct: a dialect of a language is a significant variant of that language, while an implementation of a language (or dialect) executes a program written in that language (or dialect).
Application | Dialect and latest version | ECMAScript edition |
---|---|---|
Google Chrome, the V8 engine | JavaScript | ECMA-262, edition 6 |
Mozilla Firefox, the Gecko layout engine, SpiderMonkey, and Rhino | JavaScript 1.8.5 | ECMA-262, edition 6 |
Safari, the Nitro engine | JavaScript | ECMA-262, edition 6 |
Microsoft Edge, the Chakra engine | JavaScript | ECMA-262, edition 6 |
Opera, the Carakan engine (until Opera 2015) | ECMAScript with some JavaScript 1.5 and JScript extensions[22] |
ECMA-262, edition 5.1 |
KHTML layout engine, KDE's Konqueror | JavaScript 1.5 | ECMA-262, edition 3 |
Adobe Acrobat | JavaScript 1.5 | ECMA-262, edition 3 |
OpenLaszlo | JavaScript 1.4 | ECMA-262, edition 3 |
Max/MSP | JavaScript 1.5 | ECMA-262, edition 3 |
ANT Galio 3 | JavaScript 1.5 with RMAI extensions | ECMA-262, edition 3 |