Back to Content

Firefox 68 release notes for developers

files/en-us/mozilla/firefox/releases/68/index.md

latest19.6 KB
Original Source

This article provides information about the changes in Firefox 68 that will affect developers. Firefox 68 was released on July 9, 2019.

Changes for web developers

Developer tools

Browser/web console

JavaScript debugger

  • You can now Search in all files in the current project from the debugger by pressing Shift + Ctrl + F (Windows or Linux) or Shift + Cmd + F (macOS) (Firefox bug 1320325).

Network monitor

  • The Network monitor request list now allows you to block a specific URL (Firefox bug 1151368).
  • You can now resend a network request without editing the method, URL, parameters, and headers, using the Resend command on the context menu (Firefox bug 1422014).
  • The context menu of the Network monitor Headers tab now allows you to copy all or some of the header information to the clipboard in JSON format (Firefox bug 1442249).

Page inspector

  • A button has been added to the rules panel of the Page inspector that allows you to toggle the display of any print media queries (Firefox bug 1534984).
  • The fonts panel now includes a slider to modify letter-spacing (Firefox bug 1536237).
  • A warning icon appears next to unsupported CSS properties or rules that have invalid values, to help you understand why certain styles are not being applied (Firefox bug 1306054).

Storage inspector

Other

  • The Accessibility Inspector now includes a new Check for issues feature, which will include a number of audit tools to highlight accessibility problems on your web pages. The first available check is contrast, for highlighting color contrast problems.
  • The preference that controls the visibility of internal extensions (system add-ons and hidden extensions) on the about:debugging page has been changed from devtools.aboutdebugging.showSystemAddons to devtools.aboutdebugging.showHiddenAddons (Firefox bug 1544372).
  • Responsive design mode has been redesigned — the Device Settings dialog (device selection menu > Edit List…) is now more intuitive and simpler to use (Firefox bug 1487857).

Removals

HTML

  • The {{HTMLElement("track")}} element — represented by {{domxref("HTMLTrackElement")}} — now receives a {{domxref("HTMLTrackElement.cuechange_event", "cuechange")}} event in addition to the {{domxref("TextTrack")}} itself, if the text track is a contained by a media element (Firefox bug 1548731).
  • {{htmlelement("link")}} elements support the disabled attribute again, albeit with different behavior. When disabled is set on a <link> element along with rel="stylesheet", the referenced stylesheet is not loaded during page load, and will be loaded on demand when the disabled attribute is changed to false or removed (Firefox bug 1281135).

Removals

CSS

  • CSS Scroll Snapping has been updated to the latest version of the specification (Firefox bug 1312163) and (Firefox bug 1544136), this includes:

  • The {{CSSxRef("line-clamp", "-webkit-line-clamp")}} property has been implemented for compatibility with other browsers (Firefox bug 866102).

  • Support has been added for the {{CSSxRef("::marker")}} pseudo-element (Firefox bug 205202) and animation for ::marker pseudos (Firefox bug 1538618)

  • We changed {{CSSxRef("color_value#currentcolor_keyword", "currentColor")}} to be a computed value (except for the {{cssxref("color")}} property) (Firefox bug 760345).

  • Support has been fixed for the ch length unit so it now matches the spec (fallback for no '0' glyph, vertical metrics) (Firefox bug 282126)

  • The {{CSSxRef("counter-set")}} property has been implemented. (Firefox bug 1518201).

  • We now implement list numbering using a built-in "list-item" counter; this fixes list numbering bugs (Firefox bug 288704).

  • Selector matching and parsing support has been implemented for ::part() (Firefox bug 1545430) and (Firefox bug 1545425).

  • CSS Transforms are now supported in indirectly rendered things e.g., {{SVGElement("mask")}}, {{SVGElement("marker")}}, {{SVGElement("pattern")}}, {{SVGElement("clipPath")}} (Firefox bug 1323962).

  • While we're keeping the prefixed versions of the various gradient properties {{cssxref("gradient/linear-gradient")}}, {{cssxref("gradient/radial-gradient")}}, and {{cssxref("gradient/repeating-radial-gradient")}} available for compatibility reasons, we have revised how they're parsed so that they're handled much more like the non-prefixed versions. This means that certain existing styles won't work correctly.

    In particular, the complicated syntax taking both an angle and a position will no longer work, and the to keyword in the <side-or-corner> parameter is not required for the prefixed gradient properties. You are encouraged to use the standard, non-prefixed gradient properties instead, as they're now widely supported (Firefox bug 1547939).

Removals

  • scroll-snap-coordinate, scroll-snap-destination, scroll-snap-type-x and scroll-snap-type-y have been removed.
  • The {{CSSxRef("scroll-snap-type")}} property has become a longhand, so the old shorthand syntax like scroll-snap-type:mandatory will stop working.

SVG

No changes.

JavaScript

APIs

CSS Object Model (CSSOM)

  • The legacy {{domxref("CSSStyleSheet.rules", "rules")}} property and {{domxref("CSSStyleSheet.addRule", "addRule()")}} and {{domxref("CSSStyleSheet.removeRule", "removeRule()")}} methods have been added to the {{domxref("CSSStyleSheet")}} interface. These were introduced by Internet Explorer 9 and have never managed to quite be stamped out, so they have been added to improve compatibility with the small percentage of sites that still use them (Firefox bug 1545823).

DOM

  • The Visual Viewport API has now been enabled by default on Android (Firefox bug 1512813). Adding this API to desktop versions of Firefox is being tracked in Firefox bug 1551302.
  • The {{domxref("Window")}} feature noreferrer is now supported; if specified, the new window's content is loaded without sharing the hostname, IP address, URL, or other identifying information about the host device (Firefox bug 1527287).
  • The {{domxref("HTMLImageElement.decode", "decode()")}} method on HTMLImageElement is now implemented. This can be used to trigger loading and decoding of an image prior to adding it to the DOM (Firefox bug 1501794).
  • {{domxref("XMLHttpRequest")}} has been updated to no longer accept the non-standard moz-chunked-arraybuffer value for {{domxref("XMLHttpRequest.responseType", "responseType")}}. Code still using it should be updated to use the Fetch API as a stream (Firefox bug 1120171).
  • XMLHttpRequest now outputs a warning to console if you perform a synchronous request while handling an {{domxref("Window.unload_event", "unload")}}, {{domxref("Window.beforeunload_event", "beforeunload")}}, or {{domxref("Window.pagehide_event", "pagehide")}} event (Firefox bug 980902).
  • The {{domxref("Document.cookie", "cookie")}} property has moved from the {{domxref("HTMLDocument")}} interface to the {{domxref("Document")}} interface, allowing documents other than {{Glossary("HTML")}} to use cookies (Firefox bug 144795).
  • The {{domxref("HTMLElement.focus()")}} and {{domxref("SVGElement.focus()")}} methods now accept an optional object that may contain a boolean preventScroll option specifying whether or not to block the browser from scrolling the newly-focused element into view (Firefox bug 1374045).

DOM events

  • Firefox for Android no longer incorrectly sends a {{domxref("Window.resize_event", "resize")}} event until after the first frame is painted; this improves web compatibility with sites that don't expect this event to occur (Firefox bug 1528052).
  • The dispatching of events for non-primary mouse buttons has been made to more closely follow the specification; the {{domxref("Element.click_event", "click")}} event is no longer sent when non-primary buttons are clicked, instead using {{domxref("Element.auxclick_event", "auxclick")}}. In addition, {{domxref("Element.dblclick_event", "dblclick")}} no longer fires for non-primary buttons (Firefox bug 1379466).
  • The proprietary mozPressure property has been deprecated, and will now trigger a warning in the console (Firefox bug 1165211).

Media, Web Audio, and WebRTC

  • Due to changes in the Google Play store's policies, starting with Firefox 68 for Android, the OpenH264 codec used to handle AVC/H.264 video in WebRTC connections can no longer be downloaded and installed. Therefore, fresh installs of Firefox on Android devices no longer support AVC in WebRTC calls. If you upgrade from earlier versions of Firefox and already have the codec downloaded, it will continue to work. This does not affect other platforms. For more details, see this article on SUMO or Firefox bug 1548679.

  • WebRTC has been updated to recognize that a null candidate passed into the {{domxref("RTCPeerConnection/icecandidate_event", "icecandidate")}} event handler, indicating the receipt of a candidate, instead indicates that there are no further candidates coming; when this happens the ICE gathering ({{domxref("RTCPeerConnection.iceGatheringState", "iceGatheringState")}}) state reaches complete (Firefox bug 1318167).

  • The {{domxref("RTCRtpReceiver")}} methods {{domxref("RTCRtpReceiver.getContributingSources", "getContributingSources()")}} and {{domxref("RTCRtpReceiver.getSynchronizationSources", "getSynchronizationSources()")}} now support video tracks; previously they only worked on audio (Firefox bug 1534466).

  • The Web Audio API {{domxref("MediaStreamTrackAudioSourceNode")}} interface is now supported, as is the method {{domxref("AudioContext.createMediaStreamTrackSource()")}} (Firefox bug 1324548).

  • {{domxref("RTCDataChannel.negotiated")}} is now implemented (Firefox bug 1529695).

  • The {{domxref("MediaStreamAudioSourceNode.MediaStreamAudioSourceNode", "MediaStreamAudioSourceNode()")}} constructor has been updated to match the current specification's definition that the "first audio track" in the stream is the track whose ID comes first in lexicographical order (Firefox bug 1324548).

  • {{domxref("MediaDevices.getUserMedia", "getUserMedia()")}} may no longer be used from a non-secure context; attempting to do so now throws a NotAllowedError exception. Secure contexts are those loaded using HTTPS, those located using the file:/// scheme, and those loaded from localhost. For now, if you must, you can re-enable the ability to perform insecure calls to getUserMedia() by setting the preference media.getusermedia.insecure.enabled to true (Firefox bug 1335740).

    [!NOTE] In the future, Firefox will also remove the {{domxref("navigator.mediaDevices")}} property on insecure contexts, preventing all access to the {{domxref("MediaDevices")}} APIs. This is already the case in Nightly builds.

Removals

HTTP

  • The HTTP {{HTTPHeader("Clear-Site-Data")}} header no longer supports the executionContexts directive. This was removed due to problems with interactions between interconnections among different kinds of data at different points in the navigation process and the way the specification is designed. It has been proposed that this directive be removed from the specification for this reason, among others (Firefox bug 1548034).

Removals

  • The {{HTTPHeader("Content-Security-Policy")}} directive require-sri-for is no longer supported due to concerns about its standardization status. It was previously available only behind a preference, which was off by default (Firefox bug 1386214).

Security

WebDriver conformance (Marionette)

Bug fixes

  • If WebDriver:SwitchToWindow changes the selection to a different window it now waits for its focus and activate events before returning (Firefox bug 1335085).
  • Fixed the TypeError: this.tabModal is null failure, which sometimes appeared when interacting with modal dialogs or user prompts (Firefox bug 1538782)

Other

  • Disabled the feature to force unloading background tabs on low memory conditions, to prevent top-level browser contexts from magically disappearing (Firefox bug 1553748).
  • Disabled privileged content processes that caused HTTP authentication dialogs not to appear when navigating to a website after opening a new tab (Firefox bug 1558763).

Plugins

No changes.

Changes for add-on developers

API changes

Manifest changes

No changes.

See also