Firefox 57 (Quantum) für Entwickler

Dieser Artikel bietet Informationen über die Änderungen in Firefox 57 (auch bekannt als Firefox Quantum), die Entwickler betreffen werden. Firefox 57 wurde am 14. November 2017 veröffentlicht.

Firefox 57 === Firefox Quantum

Firefox 57 wurde unter dem Namen Quantum veröffentlicht, benannt nach dem Firefox Quantum Engineering-Projekt, das sich das Ziel gesetzt hat, Firefox von Grund auf neu zu gestalten, um erhebliche Leistungs-, Stabilitäts- und visuelle Verbesserungen zu erzielen. Dies ist die erste Version von Firefox, die einige dieser Verbesserungen enthält, weshalb wir diesen Anlass hervorheben wollten.

Hinweis: Um mehr über die Quantum-Features in dieser Version zu erfahren, lesen Sie Firefox Quantum Developer Edition: der schnellste Firefox aller Zeiten mit Photon UI und besseren Werkzeugen von Dan Callahan.

Firefox's neuer paralleler CSS-Engine – auch bekannt als Quantum CSS oder Stylo – ist in Firefox 57 für Desktop standardmäßig aktiviert, mit mobilen Versionen von Firefox, die später folgen werden. Entwickler sollten nichts signifikant anderes bemerken, abgesehen von einer Vielzahl von Leistungsverbesserungen. Es gibt jedoch einige kleinere funktionale Unterschiede in Stylo, die implementiert wurden, um nicht standardmäßiges Gecko-Verhalten zu beheben, das beseitigt werden sollte. Wir werden über solche Unterschiede auf Referenzseiten und in den Versionshinweisen berichten, wo es angebracht ist (siehe Quantum CSS-Hinweise).

Änderungen für Webentwickler

Entwicklerwerkzeuge

Keine Änderungen.

HTML

CSS

Quantum CSS-Hinweise

Folgende Bugs wurden in Quantum behoben:

  • Radiale Gradient-Werte wie radial-gradient(circle gold,red) funktionieren im alten Gecko-Stilsystem, obwohl sie es nicht sollten, wegen des fehlenden Kommas zwischen circle und gold (Firefox-Bug 1383323).
  • Wenn Sie ein offscreen-Element onscreen animieren, aber eine Verzögerung angeben, führt Gecko auf einigen Plattformen, z.B. Windows, kein Redraw durch (Firefox-Bug 1383239).
  • In Gecko können <details> Elemente nicht standardmäßig geöffnet werden, wenn sie ein aktives animation haben (Firefox-Bug 1382124).
  • In Gecko funktionieren transitions nicht, wenn von einem text-shadow mit einer angegebenen Farbe auf einen text-shadow ohne angegebene Farbe übergegangen wird (Firefox-Bug 726550).
  • In Gecko kann das Abbrechen einer füllenden Animation (z.B. mit animation-fill-mode: forwards gesetzt) eine auf dasselbe Element gesetzte Transition auslösen, obwohl nur einmal (siehe Firefox-Bug 1192592 und diese Testfälle für mehr Informationen). Im Allgemeinen sollten deklarative Animationen keine Übergänge auslösen.
  • Animationen, die em-Einheiten verwenden, sind in Gecko nicht von Änderungen an der font-size auf dem übergeordneten Element des animierten Elements betroffen, obwohl sie es sein sollten (Firefox-Bug 1254424).
  • Gecko geht auch anders mit der Vererbung von font-size um als Quantum CSS, was bedeutet, dass bei einigen Spracheinstellungen die vererbten Schriftgrößen kleiner ausfallen als erwartet (siehe Firefox-Bug 1391341).
  • Gecko verwendet denselben Mechanismus, der beim Parsen eines url-tokens verwendet wird, wenn er die domain() oder url-prefix() URL-Abgleichsfunktionen für eine @-moz-document Regel parst. Quantum CSS verwendet nicht denselben Mechanismus und betrachtet Tokens nicht als ungültig, wenn sie Klammern oder Anführungszeichen enthalten (Firefox-Bug 1362333).
  • In Gecko schlägt das Setzen einer Systemschriftart als Wert eines canvas 2D-Kontextes font (z.B. menu) fehl, und die Schriftart wird nicht wie erwartet zurückgegeben (nichts wird zurückgegeben). Dies wurde in Quantum behoben. (Firefox-Bug 1374885).
  • In Gecko wird ein abgetrennter Teilbaum (z.B. ein <div>, der mit createElement() erstellt wurde, aber noch nicht in den DOM eingefügt wurde) als Block-Level-Element gesetzt. In Quantum CSS wird dies als Inline gesetzt, gemäß der Spezifikation (Firefox-Bug 1374994).
  • In Gecko werden calc() Ausdrücke abgelehnt — was dazu führt, dass der Wert ungültig ist — wenn sie als Radiuskomponente einer radial-gradient() Funktion verwendet werden (Firefox-Bug 1376019).
  • In Gecko wird calc(1*2*3) nicht erfolgreich geparst; Quantum CSS behebt dies (Firefox-Bug 1379467).
  • In Quantum CSS wird calc() überall unterstützt, wo es laut Spezifikation unterstützt werden sollte (Firefox-Bug 1350857). In Gecko ist dies nicht der Fall.
  • Gecko hat einen Bug, bei dem die ::before und ::after Pseudo-Elemente immer noch generiert werden, selbst wenn der content Eigenschaftswert auf normal oder none gesetzt ist. Gemäß der Spezifikation sollten sie es nicht (Firefox-Bug 1387931).
  • Ein weiterer Gecko-Bug bedeutet, dass die background-position Eigenschaft nicht zwischen zwei Werten mit unterschiedlicher Anzahl von <position> Werten übergehen kann, zum Beispiel background-position: 10px 10px; und background-position: 20px 20px, 30px 30px; (siehe Firefox-Bug 1390446).

SVG

Keine Änderungen.

JavaScript

APIs

Neue APIs

DOM

DOM-Ereignisse

Keine Änderungen.

Medien und WebRTC

  • Unterstützung für Nachrichten beliebiger Größe (bis zu 1GiB, obwohl 256kiB interoperabler ist) wird jetzt auf RTCDataChannel durch die Verwendung des End-of-record (EOR) Flags auf SCTP-Nachrichten unterstützt. Siehe Understand message size limits für mehr Informationen (Firefox-Bug 979417).

    Hinweis: Da Firefox das SCTP ndata Protokoll, das die Fähigkeit bietet, SCTP-Nachrichten aus mehreren Quellen zu verflechten, noch nicht unterstützt, kann das Senden großer Datenobjekte erhebliche Verzögerungen bei allen anderen SCTP-Übertragungen verursachen. Siehe Firefox-Bug 1381145, um den Fortschritt bei der Implementierung und Bereitstellung von Ndata-Unterstützung in Firefox zu verfolgen.

  • Die RTCDataChannel.send() Methode kann jetzt eine TypeError-Ausnahme auslösen, wenn die Größe der Nachricht, die Sie senden möchten, nicht mit dem empfangenden Benutzeragenten kompatibel ist (dies wird im Rahmen von Firefox-Bug 979417 implementiert).

  • Die MediaStream Recording API wurde aktualisiert, sodass error Ereignisse, die gesendet werden, um Probleme zu melden, die beim Aufzeichnen auftreten, jetzt vom Typ MediaRecorderErrorEvent sind, anstatt generische Ereignisse zu sein.

  • Die Dokumentation rund um OfflineAudioContext wurde aktualisiert, da die Eingänge seines Konstruktors jetzt in einem Objekt angegeben werden können, anstatt als Liste von Parametern (Firefox-Bug 1388591).

  • Die Web Audio API unterstützt nun ordnungsgemäß die Ausgabe über mehrere Kanäle (Firefox-Bug 1378070).

Sicherheit

  • resource:// URLs leaken keine Informationen mehr (Firefox-Bug 863246)
  • Daten-URLs werden jetzt als eindeutige opake Ursprünge behandelt, anstatt die Herkunft des für die Navigation verantwortlichen Einstellungsobjekts zu übernehmen (Firefox-Bug 1324406).

Plugins

Keine Änderungen.

Sonstiges

  • Der Firefox Headless-Modus umfasst jetzt ein -screenshot-Flag, das es ermöglicht, Website-Screenshots direkt über die Befehlszeile zu machen (Firefox-Bug 1378010).

Entfernungen von der Webplattform

HTML

  • <link rel="preload"> (siehe Preloading content with rel="preload") wurde in Firefox 57 aufgrund verschiedener Webkompatibilitätsprobleme deaktiviert (z.B. Firefox-Bug 1405761). Eine verbesserte Version, die auch für nicht-cacheable Ressourcen funktioniert, wird voraussichtlich in Firefox 58 eingeführt.

APIs

SVG

Keine Änderungen.

Änderungen für Add-on- und Mozilla-Entwickler

Hinweis: Ab Firefox 57 wurde jede Unterstützung für auf XPCOM-basierte Add-ons entfernt. Alle Erweiterungen müssen in die neuen Browsererweiterungen (auch bekannt als WebExtensions) umgewandelt werden, oder sie werden nicht funktionieren.

WebExtensions

Die folgenden APIs wurden hinzugefügt oder erweitert:

Ältere Versionen