
differ should be differentiate https://developer.mozilla.org/en-US/search is broken so I changed it to https://developer.mozilla.org/en-US/ Other language changes are to improve readability and correct minor language errors
113 lines
5.7 KiB
Markdown
113 lines
5.7 KiB
Markdown
# Browser environment, specs
|
|
|
|
The JavaScript language was initially created for web browsers. Since then, it has evolved into a language with many uses and platforms.
|
|
|
|
A platform may be a browser, or a web-server or another *host*, or even a "smart" coffee machine if it can run JavaScript. Each of these provides platform-specific functionality. The JavaScript specification calls that a *host environment*.
|
|
|
|
A host environment provides its own objects and functions in addition to the language core. Web browsers give a means to control web pages. Node.js provides server-side features, and so on.
|
|
|
|
Here's a bird's-eye view of what we have when JavaScript runs in a web browser:
|
|
|
|

|
|
|
|
There's a "root" object called `window`. It has two roles:
|
|
|
|
1. First, it is a global object for JavaScript code, as described in the chapter <info:global-object>.
|
|
2. Second, it represents the "browser window" and provides methods to control it.
|
|
|
|
For instance, we can use it as a global object:
|
|
|
|
```js run global
|
|
function sayHi() {
|
|
alert("Hello");
|
|
}
|
|
|
|
// global functions are methods of the global object:
|
|
window.sayHi();
|
|
```
|
|
|
|
And we can use it as a browser window, to show the window height:
|
|
|
|
```js run
|
|
alert(window.innerHeight); // inner window height
|
|
```
|
|
|
|
There are more window-specific methods and properties, which we'll cover later.
|
|
|
|
## DOM (Document Object Model)
|
|
|
|
The Document Object Model, or DOM for short, represents all page content as objects that can be modified.
|
|
|
|
The `document` object is the main "entry point" to the page. We can change or create anything on the page using it.
|
|
|
|
For instance:
|
|
```js run
|
|
// change the background color to red
|
|
document.body.style.background = "red";
|
|
|
|
// change it back after 1 second
|
|
setTimeout(() => document.body.style.background = "", 1000);
|
|
```
|
|
|
|
Here, we used `document.body.style`, but there's much, much more. Properties and methods are described in the specification: [DOM Living Standard](https://dom.spec.whatwg.org).
|
|
|
|
```smart header="DOM is not only for browsers"
|
|
The DOM specification explains the structure of a document and provides objects to manipulate it. There are non-browser instruments that use DOM too.
|
|
|
|
For instance, server-side scripts that download HTML pages and process them can also use the DOM. They may support only a part of the specification though.
|
|
```
|
|
|
|
```smart header="CSSOM for styling"
|
|
There's also a separate specification, [CSS Object Model (CSSOM)](https://www.w3.org/TR/cssom-1/) for CSS rules and stylesheets, that explains how they are represented as objects, and how to read and write them.
|
|
|
|
The CSSOM is used together with the DOM when we modify style rules for the document. In practice though, the CSSOM is rarely required, because we rarely need to modify CSS rules from JavaScript (usually we just add/remove CSS classes, not modify their CSS rules), but that's also possible.
|
|
```
|
|
|
|
## BOM (Browser Object Model)
|
|
|
|
The Browser Object Model (BOM) represents additional objects provided by the browser (host environment) for working with everything except the document.
|
|
|
|
For instance:
|
|
|
|
- The [navigator](mdn:api/Window/navigator) object provides background information about the browser and the operating system. There are many properties, but the two most widely known are: `navigator.userAgent` -- about the current browser, and `navigator.platform` -- about the platform (can help to differentiate between Windows/Linux/Mac etc).
|
|
- The [location](mdn:api/Window/location) object allows us to read the current URL and can redirect the browser to a new one.
|
|
|
|
Here's how we can use the `location` object:
|
|
|
|
```js run
|
|
alert(location.href); // shows current URL
|
|
if (confirm("Go to Wikipedia?")) {
|
|
location.href = "https://wikipedia.org"; // redirect the browser to another URL
|
|
}
|
|
```
|
|
|
|
The functions `alert/confirm/prompt` are also a part of the BOM: they are not directly related to the document, but represent pure browser methods for communicating with the user.
|
|
|
|
```smart header="Specifications"
|
|
The BOM is a part of the general [HTML specification](https://html.spec.whatwg.org).
|
|
|
|
Yes, you heard that right. The HTML spec at <https://html.spec.whatwg.org> is not only about the "HTML language" (tags, attributes), but also covers a bunch of objects, methods, and browser-specific DOM extensions. That's "HTML in broad terms". Also, some parts have additional specs listed at <https://spec.whatwg.org>.
|
|
```
|
|
|
|
## Summary
|
|
|
|
Talking about standards, we have:
|
|
|
|
DOM specification
|
|
: Describes the document structure, manipulations, and events, see <https://dom.spec.whatwg.org>.
|
|
|
|
CSSOM specification
|
|
: Describes stylesheets and style rules, manipulations with them, and their binding to documents, see <https://www.w3.org/TR/cssom-1/>.
|
|
|
|
HTML specification
|
|
: Describes the HTML language (e.g. tags) and also the BOM (browser object model) -- various browser functions: `setTimeout`, `alert`, `location` and so on, see <https://html.spec.whatwg.org>. It takes the DOM specification and extends it with many additional properties and methods.
|
|
|
|
Additionally, some classes are described separately at <https://spec.whatwg.org/>.
|
|
|
|
Please note these links, as there's so much to learn that it's impossible to cover everything and remember it all.
|
|
|
|
When you'd like to read about a property or a method, the Mozilla manual at <https://developer.mozilla.org/en-US/> is also a nice resource, but the corresponding spec may be better: it's more complex and longer to read, but will make your fundamental knowledge sound and complete.
|
|
|
|
To find something, it's often convenient to use an internet search "WHATWG [term]" or "MDN [term]", e.g <https://google.com?q=whatwg+localstorage>, <https://google.com?q=mdn+localstorage>.
|
|
|
|
Now, we'll get down to learning the DOM, because the document plays the central role in the UI.
|