1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
---
title: JavaScript Technologieübersicht
slug: Web/JavaScript/JavaScript_technologies_overview
translation_of: Web/JavaScript/JavaScript_technologies_overview
original_slug: Web/JavaScript/JavaScript_technologieuebersicht
---
<div>{{JsSidebar("Introductory")}}</div>
<h2 id="Einleitung">Einleitung</h2>
<p>Während <a href="/en-US/docs/Web/HTML">HTML</a> die Struktur einer Webseite definiert und <a href="/en-US/docs/Web/CSS">CSS</a> den Style angibt, mit dem der Inhalt der Webseite dargestellt wird, ermöglicht <a href="/en-US/docs/Web/JavaScript">JavaScript</a> das Erstellen von interaktiven Webseiten und Rich Web Applications.</p>
<p>Der Begriff "JavaScript" umfasst im Kontext von Web-Browsern mehrere Elemente. Darunter befinden sich der Sprachkern (ECMAScript) und einige <a href="/en-US/docs/Web/Reference/API">Web APIs</a>, die auch das DOM (Document Object Model) enthalten.</p>
<h2 id="Sprachkern_von_JavaScript_(ECMAScript)">Sprachkern von JavaScript (ECMAScript)</h2>
<p>Der Sprachkern von JavaScript wurde vom ECMA TC39 Kommittee als die Sprache <a href="/en-US/docs/JavaScript/Language_Resources" title="en-US/docs/JavaScript/Language_Resources">ECMAScript</a> standardisiert. Die aktuellste Version der Spezifikation ist <a class="external" href="http://ecma-international.org/ecma-262/5.1/">ECMAScript 5.1</a>.</p>
<p>Der Sprachkern wird auch in Umgebungen außerhalb von Webbrowsern eingesetzt, wie zum Beispiel in <a href="http://nodejs.org/">node.js</a>.</p>
<h3 id="Was_gehört_alles_zu_ECMAScript">Was gehört alles zu ECMAScript?</h3>
<p>Neben anderen Dingen definiert ECMAScript folgende Punkte:</p>
<ul>
<li>Die Sprachsyntax (Regeln zum Parsen, Schlüsselwörter, Kontrollfluss, Objektinitialisierung...)</li>
<li>Mechanismen zur Fehlerbehandlung (throw, try/catch, Erstellung von benutzerdefinierten Fehlertypen)</li>
<li>Typen (boolean, number, string, function, object...)</li>
<li>Das globale Objekt. In Webbrowsern ist dies das window Objekt. ECMAScript definiert hierbei nur die APIs, die nicht browserspezifisch sind. z.B.: <code>parseInt</code>, <code>parseFloat</code>, <code>decodeURI</code>, <code>encodeURI</code>...</li>
<li>Vererbungsmechanismus basierend auf Prototypen</li>
<li>Eingebaute Objekte und Funktionen (<code>JSON</code>, <code>Math</code>, <code>Array.prototype</code> Methoden, Object introspection methods...)</li>
<li>Strict mode</li>
</ul>
<h3 id="Webbrowserunterstützung">Webbrowserunterstützung</h3>
<p>Im August 2014 implementierten die aktuellen Versionen der verbreitesten Webbrowser <a href="/en-US/docs/Web/JavaScript/New_in_JavaScript/ECMAScript_5_support_in_Mozilla">ECMAScript 5.1</a>. Es sind aber noch ältere Versionen in Verwendung, welche ECMAScript 3 und nur Teile von ECMAScript 5 implementieren. Moderne Webbrowsers implementieren bereits große Teile von <a href="/en-US/docs/Web/JavaScript/New_in_JavaScript/ECMAScript_6_support_in_Mozilla">ECMAScript 6</a>.</p>
<h3 id="Zukunft">Zukunft</h3>
<p>Die vorgeschlagene vierte Version von ECMA-262 (<strong>ECMAScript 4</strong> oder <strong>ES4</strong>) hätte das erste große Update von ECMAScript seit der dritten Version, welche in 1999 veröffentlicht wurde, sein sollen. Im August 2008 wurde der Vorschlag zur vierten Version von ECMAScript unter dem Projekt <a class="external" href="http://wiki.ecmascript.org/doku.php?id=harmony:harmony">ECMAScript Harmony</a> reduziert, welches zum Beispiel Proxies oder das <code>const</code> Schlüsselwort definiert. Der Fortschirtt kann <a class="external" href="http://wiki.ecmascript.org/doku.php">hier</a> verfolgt werden. Die Veröffentlichung der sechsten Hauptversion des Standards wird im Jahr 2015 erwartet.</p>
<h2 id="Internationalization_API">Internationalization API</h2>
<p>Die <a href="http://ecma-international.org/ecma-402/1.0/" title="http://ecma-international.org/ecma-402/1.0/">ECMAScript Internationalization API Specification</a> ist eine Erweiterung zur ECMAScript Sprachspezifikation, welche vom Ecma TC39 Kommittee standardisiert wird. Die Internationalization API bietet Textvergleiche (string Vergleiche), Formatierung von Zahlen, Datum und Zeit für JavaScript Applikationen, und lässt Applikationen die Sprache wählen, um die Funktionalität für die eigenen Bedürfnisse anpassen zu können. Der Standard wurde im Dezember 2012 freigegeben. Der Status über die Implementierung in Webbrowsern ist in der Documentation von <a href="/en-US/docs/JavaScript/Reference/Global_Objects/Intl" title="/en-US/docs/JavaScript/Reference/Global_Objects/Intl"><code>Intl</code> object</a> aufgezeichnet.</p>
<h2 id="Die_Web_APIs_und_der_DOM">Die Web APIs und der DOM</h2>
<h3 id="WebIDL">WebIDL</h3>
<p>Die <a class="external" href="http://www.w3.org/TR/WebIDL/" title="http://dev.w3.org/2006/webapi/WebIDL/">WebIDL specification</a> verbindet die DOM Technologien und ECMAScript miteinander.</p>
<h3 id="Der_Kern_des_DOM">Der Kern des DOM</h3>
<p>Das Document Object Model (DOM) ist eine plattform- und <strong>sprachunabhängige Konvention</strong> zur Repräsentation und Interaktion mit Objekten in HTML, XHTML und XML Dokumenten. Objekte im <strong>DOM Baum</strong> können über Methoden angesprochen und durch Aufrufen ihrer Methoden verändert werden. Das Core Document Object Model ist von der W3C standardisiert worden. Es definiert sprachspezifische Schnittstellen, welche HTML und XML Dokuments als Objekte abstrahieren und Mechanismen zur Manipulation dieser Abstraktion. Zusätzlich definiert der DOM auch:</p>
<ul>
<li>Die Dokumentstruktur, ein Baummodell, und die DOM Event Architektur im <a class="external" href="http://dvcs.w3.org/hg/domcore/raw-file/tip/Overview.html" title="http://dvcs.w3.org/hg/domcore/raw-file/tip/Overview.html">DOM core</a>: <code>Node</code>, <code>Element</code>, <code>DocumentFragment</code>, <code>Document</code>, <code>DOMImplementation</code>, <code>Event</code>, <code>EventTarget</code>, …</li>
<li>Eine weniger strenge Definition der DOM Event Architektur und spezifische Events im <a class="external" href="http://dev.w3.org/2006/webapi/DOM-Level-3-Events/html/DOM3-Events.html" title="http://dev.w3.org/2006/webapi/DOM-Level-3-Events/html/DOM3-Events.html">DOM events</a>.</li>
<li>Andere Definitionen wie zum Beispiel <a class="external" href="http://www.w3.org/TR/DOM-Level-2-Traversal-Range/traversal.html">DOM Traversal</a> und <a class="external" href="http://html5.org/specs/dom-range.html" title="http://html5.org/specs/dom-range.html">DOM Range</a>.</li>
</ul>
<p>Aus der Sicht von ECMAScript werden Objekte, die in der DOM Spezifikation definiert sind, "host objects" genannt.</p>
<h3 id="HTML_DOM">HTML DOM</h3>
<p><a class="external" href="http://www.whatwg.org/html" title="http://www.whatwg.org/html">HTML</a>, die Markup-Sprache im Web, ist mit Bezug auf den DOM definiert. HTML liegt eine Schicht über den abstrakten Konzepten vom DOM Kern und definiert zusätzlich die <em>Bedeutung</em> von Elementen. Der HTML DOM beinhaltet zum Beispiel die <code>className</code> Eigenschaft von HTML Elementen oder APIs wie {{ domxref("document.body") }}.</p>
<p>Die HTML Spezifikation definiert auch Einschränkungen auf Documenten. So müssen zum Beispiel die direkten Kindelemente der ungeordneten Liste <code>ul</code> alle <code>li</code> Elemente sein, welche die Listeneinträge repräsentieren. Im Allgemeinen verbietet die Spezifikation auch die Verwendung von Elementen und Attributen, die nicht im Standard definiert sind.</p>
<p>Suchen Sie nach dem <a href="/en-US/docs/DOM/document" title="https://developer.mozilla.org/en-US/docs/DOM/document"><code>Document</code> Objekt</a>, <a href="/en-US/docs/DOM/window" title="/en-US/docs/DOM/window"><code>Window</code> Objekt</a>, oder anderen DOM Elementen? Besuchen Sie die <a href="/en-US/docs/Web/API/Document_Object_Model" title="/en-US/docs/Gecko_DOM_Reference">DOM Dokumentation</a>.</p>
<h3 id="Andere_APIs">Andere APIs</h3>
<ul>
<li>Die <code>setTimeout</code> und die <code>setInterval</code> Funktionen wurden zuerst auf dem <code><a class="external" href="http://www.whatwg.org/html/#window" title="http://www.whatwg.org/html/#window">Window</a></code> interface im HTML Standard definiert.</li>
<li><a class="external" href="https://dvcs.w3.org/hg/xhr/raw-file/tip/Overview.html" title="http://dev.w3.org/2006/webapi/XMLHttpRequest-2/">XMLHttpRequest.</a> API die das Senden von asynchronen HTTP Request ermöglicht.</li>
<li><a class="external" href="http://dev.w3.org/csswg/cssom/">CSS Object Model.</a> Das CSSOM wird zur Abstraktion von CSS Regeln als Objekte verwendet.</li>
<li><a class="external" href="http://www.whatwg.org/specs/web-workers/current-work/">WebWorkers.</a> API die die Verwendung von paralleler Verarbeitung ermöglicht.</li>
<li><a class="external" href="http://www.whatwg.org/C/#network">WebSockets.</a> API die eine low-level bidirektionale Kommunikation ermöglicht.</li>
<li><a class="external" href="http://www.whatwg.org/html/#2dcontext" title="http://www.whatwg.org/html/#2dcontext">Canvas 2D Context.</a> Grafik API für das canvas Element.</li>
</ul>
<h3 id="Webbrowserunterstützung_2">Webbrowserunterstützung</h3>
<p>Jeder Webbrowser muss erfahren, dass <a class="external" href="http://ejohn.org/blog/the-dom-is-a-mess/">der DOM ein Chaos</a> ist. Die Einheitlichkeit der Webbrowserunterstützung variiert teilweise stark von Feature zu Feature. Die Ursache dafür ist, dass viele der wichtigen DOM Features kaum oder unklare Spezifikationen hatten. Zusätzlich implementieren verschiedene Webbrowser eigene inkompatible Features für überlappende Einsatzszenarien (wie das Event Model vom Internet Explorer). Der aktuelle Trend (Stand Juni 2011) ist, das die W3C und teilweise die WHATWG ältere Features detaillierter definieren, damit die Interoperabilität verbessert werden kann. Diesem Trend folgend verbessern Webbbrowser ihre Implementierungen basierend auf den detaillierten Spezifikationen.</p>
<p>Eine allgemeine aber möglicherweise nicht vollkommen zuverlässiger Ansatz für cross-browser Kompatibilität ist der Einsatz einer JavaScript Bibliothek. Diese Bibliotheken abstrahieren DOM Features und gewährleisten den APIs, dass sie in verschiedenen Webbrowsern einheitlich funktionieren. Einige der meistverbreitesten Frameworks sind <a class="external" href="http://jquery.com/">jQuery</a>, <a class="external" href="http://www.prototypejs.org/">prototype</a>, und <a class="external" href="http://developer.yahoo.com/yui/">YUI</a>.</p>
|