- JavaScript, where does it live?
- The ECMAScript Engine
- What does the engine actually do?
- Visual guide based on V8
- How many of them are there?
- Engines Differences
- The ECMAScript runtime
- Runtimes Differences
- Similarities
- Javascript and the web
- HTML
- CSS
- TL;DR
- Complementary readings
During this walk we mentioned several times a set of concepts related to JavaScript (but not only) that we'll explore a little deeper today.
- ECMA International
- ECMAScript
- ECMA-262
- JavaScript
- JavaScript engine
- JavaScript Runtime
Let's remember what are they.
ECMA International is an organization dedicate to define and maintain technology standards, one of the standards is ECMAScript identified as ECMA-262 which specifies the rules, details and guidelines so you can create a programming language in compliance to ECMAScript standard. JavaScript is one of this languages (one of many) and even though historically it was created before the standard, today it follows it. In order to be interpreted and executed, a programming language might need an engine, JavaScript is one of this cases but all ECMAScript compliant languages will need an engine; and this statement will generally apply to the ECMAScript engine itself, which will require a Host Environment as well. This Host environment (a.k.a ECMAScript Runtime) will provide to the engine the necessary elements to interact with other systems.
So what does the engine actually do? (briefly)
- once your text file is loaded, the engine will performing a lexical analysis by reading the sequences of characters and try to convert them into a sequence of meaningful strings (tokens) for the specific language (a.k.a. tokenization).
- once the lexer successfully identifies those meaningful pieces it's time to perform a syntactic analysis (parsing) to make sure the tokens can be related making valid expressions.
- no errors so far, so it's time for a semantic analysis, here a lot of things will happen, essentially to make sure the program can be accurately represented and the resources of the program such as types, bindings and assignments are valid and the Symbol Table could be successfully created and the intermediate representation of the code was generated
- no what? It's time to convert that IR into something the machine can execute (e.g. machine code). In the modern JavaScript engines (originally introduced by V8) this happens in runtime (during execution) and is known as JIT
- the? Again, pretty much all modern ECMAScript engines, especially JavaScript engines implement some form of optimization (e.g V8's TurboFan)
HEAP (memory allocation) | EXECUTION CONTEXT STACK (call stack) |
---|---|
Here the engine stores the memory addresses for compound data ( e.g. objects and object subtypes like functions, arrays). This memory doesn't depend on the execution context, will be persisted until the Garbage Collector can claim it. - Garbage Collector (Orinoco) | The ECS is tied to the function execution. When a function is called, it'll be added to the stack in a LIFO order. It runs synchronously and when its execution has been completed it'll be popped off the stack and the engine will take the next item on the stack. Javascript has only ONE ECS, therefore one thing at a time can be executed. Interpreters (TurboFan) - Optimizers (Ignition) |
More than 30
Yup, at least that's the list of known implementation but there might be more. Some of them compile to machine code using JIT, some doesn't, some are new, or old, designed for web browsers or to be embedded.
You can check a quite long List of ECMAScript engines in Wikipedia
Comparison between different JavaScript engines.
We said "This Host environment (a.k.a ECMAScript Runtime) will provide to the engine the necessary elements to interact with other systems.", can we have a concrete example?
Let's try to be simple: We know two runtimes that share the same engine: V8 is the JavaScript engine for both Chrome and Node.js, the overlapping surface between both runtimes is huge but there are also big differences. See the table below.
- Chrome
- Web APIs (tons of them)
window
predefined global objectlocation
global objectdocument
global objectimport
- ES6 modules
- Node.js
- headless
global
predefined global objectrequire
process
- CommonJs modules
- Timers
- Event Loop
- Callback Queue
Why should I care? because even though we're writing JavaScript, depending on the runtime for the same engine, our program might shamefully fail or it could be extremely hard to test.
Here some more cases of mixed environments differences from YDKJS: Types & Grammar - Mixed Environment JavaScript by Kyle Simpson.
Despite the fact that JavaScript, today, is much more than a language for the web; it's still one of the heaviest usage of the language, particularly webb applications delivered as "web pages". Therefore is extremely important that you know not only JavaScript but also HTML and CSS (.there's an interesting Roadmap to becoming a web developer in 2019 written by Kamran Ahmed if you want to read more)
We won't get deep into them as that's not the scope of this course, but at least we'll review their definitions and some basic features.
Hypertext Markup Language (HTML) is the standard markup language for documents designed to be displayed in a web browser. It can be assisted by technologies such as Cascading Style Sheets (CSS) and scripting languages such as JavaScript.
Web browsers receive HTML documents from a web server or from local storage and render the documents into multimedia web pages. HTML describes the structure of a web page semantically and originally included cues for the appearance of the document.
HTML elements are the building blocks of HTML pages. With HTML constructs, images and other objects such as interactive forms may be embedded into the rendered page. HTML provides a means to create structured documents by denoting structural semantics for text such as headings, paragraphs, lists, links, quotes and other items. HTML elements are delineated by tags, written using angle brackets. Tags such as
<img />
and<input />
directly introduce content into the page. Other tags such as<p>
surround and provide information about document text and may include other tags as sub-elements. Browsers do not display the HTML tags, but use them to interpret the content of the page.HTML can embed programs written in a scripting language such as JavaScript, which affects the behavior and content of web pages. Inclusion of CSS defines the look and layout of content.
The World Wide Web Consortium (W3C), former maintainer of the HTML and current maintainer of the CSS standards, has encouraged the use of CSS over explicit presentational HTML since 1997.
Source: Wikipedia
Cascading Style Sheets (CSS) is a style sheet language used for describing the presentation of a document written in a markup language like HTML. CSS is a cornerstone technology of the World Wide Web, alongside HTML and JavaScript.
CSS is designed to enable the separation of presentation and content, including layout, colors, and fonts. This separation can improve content accessibility, provide more flexibility and control in the specification of presentation characteristics, enable multiple web pages to share formatting by specifying the relevant CSS in a separate .css file, and reduce complexity and repetition in the structural content.
Separation of formatting and content also makes it feasible to present the same markup page in different styles for different rendering methods, such as on-screen, in print, by voice (via speech-based browser or screen reader), and on Braille-based tactile devices. CSS also has rules for alternate formatting if the content is accessed on a mobile device.
The name cascading comes from the specified priority scheme to determine which style rule applies if more than one rule matches a particular element. This cascading priority scheme is predictable.
The CSS specifications are maintained by the World Wide Web Consortium (W3C). Internet media type (MIME type) text/css is registered for use with CSS by RFC 2318 (March 1998). The W3C operates a free CSS validation service for CSS documents.
Source: Wikipedia
- JavaScript Engine: takes care of the analysis and execution of the code
- JavaScript Runtime: takes care of running the JavaScript engine and provide to it the mechanisms to communicate with other systems (e.g. timers, external resources) through specific APIs
- HTML: takes care of presenting the information to the browser in a semantic way by delivering a structured document and inform the browser about external resources required for the presentation (e.g. js, css, fonts)
- CSS: takes care of defining the structured document (HTML) to cover different presentational (rendering) needs such as visual aspect (e.g desktop vs mobile displays), specific devices (e.g. printers), accessibility (e.g. screen readers, Braille tactile devices)
- The Javascript Runtime Environment by Jaime Uttariello
- What’s the difference between JavaScript and ECMAScript? by Michael Aranda
- JavaScript Internals: JavaScript engine, Run-time environment & setTimeout Web API by Rupesh Mishra
- JavaScript V8 Engine Explained by Kadishay
- How JavaScript works: inside the V8 engine + 5 tips on how to write optimized code by Alexander Zlatkov
- Understanding How the Chrome V8 Engine Translates JavaScript into Machine Code by Mayank Tripathi