Path: blob/main/files/en-us/mozilla/firefox/releases/27/index.md
6581 views
------{{FirefoxSidebar}}
Firefox 27 was released on February 4, 2014. This article lists key changes that are useful not only for web developers, but also Firefox and Gecko developers as well as add-on developers.
Changes for Web developers
Developer Tools
Breakpoints can now be set on DOM events.
JavaScript in the debugger panel can be unminified, using the { } button.
The inspector now has an "edit-element-html" feature, without needing an add-on.
Background-URLs and colors have preview in inspector. Even hovering over canvas elements will give a pop-up with an image preview.
Reflow logging has been added.
Styles of SVG elements are now inspectable (Webkit bug 921191).
Failure to find the image when clicking URL link in CSS inspector has been fixed (Webkit bug 921686).
The {{HTTPHeader("SourceMap", "X-SourceMap")}} header is now supported (Firefox bug 765993).
More details in this post.
CSS
The
-moz-graband-moz-grabbingkeywords on the CSS {{cssxref("cursor")}} property have been unprefixed tograbandgrabbing(Firefox bug 880672).Support for the
-moz-hsla()and-moz-rgba()functional notations has been dropped. Only the unprefixed versions,hsla()andrgba()are supported from now on (Firefox bug 893319).The "
true" value for {{cssxref("text-align")}} has been added (Firefox bug 929991).Experimental support of
position:stickyis now active by default on non-release builds (Firefox bug 902992). For releases builds, thelayout.css.sticky.enabledpreference still needs to be set totrue.The {{cssxref("all")}} shorthand property has been added (Firefox bug 842329).
The {{cssxref("unset")}} global value has been added; it allows to reset any CSS property (Firefox bug 921731).
Curly brackets are no longer allowed in HTML
styleattributes: doing<div style="{ display: none }">was working in quirks mode, but won't anymore Firefox bug 915053.The {{cssxref("overflow")}} property now works on {{HTMLElement("fieldset")}} (Firefox bug 261037).
HTML
The
colorvalue of the {{HTMLElement("input")}} {{htmlattrxref("type", "input")}} attribute has been implemented on desktop platforms. It was already available on mobile ones.The
allow-popupsdirective is now supported with the {{htmlattrxref("sandbox", "iframe")}} attribute of the {{HTMLElement("iframe")}} element (Firefox bug 766282).Blending of HTML elements using the {{cssxref("mix-blend-mode")}} property has been implemented. The
layout.css.mix-blend-mode.enabledpreference must be set totrue(Firefox bug 902525).The {{domxref("Object.typeMustMatch", "typeMustMatch")}} property of the {{HTMLElement("object")}} element is now supported (Firefox bug 827160).
JavaScript
ECMAScript 2015 implementation continues!
The spread operator is now supported in Function calls (Firefox bug 762363).
The mathematical function {{jsxref("Global_Objects/Math/hypot", "Math.hypot()")}} has been implemented (Firefox bug 896264).
The {{jsxref("Operators/yield*", "yield*")}} expression is now implemented (Firefox bug 666396).
The
MapIterator,SetIteratorandArrayIteratorobjects now match the specification (Firefox bug 881226).for...of loops now expect the ES2015 standard iterator protocol moving away from SpiderMonkey old iterator protocol using
StopIteration.{{jsxref("String.match")}} and {{jsxref("String.replace")}} now reset {{jsxref("RegExp.lastIndex")}} (Firefox bug 501739).
Interfaces/APIs/DOM
Support for the two
setRange()methods on the {{domxref("HTMLInputElement")}} interface has been added (Firefox bug 850364).Support for the two
setRange()methods on the {{domxref("HTMLTextAreaElement")}} interface has been added (Firefox bug 918940).The methods
getAllKeys()andopenKeyCursor()have been added to {{domxref("IDBObjectStore")}} (Firefox bug 920633 and Firefox bug 920800).The {{domxref("HTMLFormControlsCollection")}} interface has been implemented (Firefox bug 913920).
The {{domxref("CanvasRenderingContext2D")}} interface now supports the two methods {{domxref("CanvasRenderingContext2D.getLineDash()", "getLineDash()")}} and {{domxref("CanvasRenderingContext2D.setLineDash()", "setLineDash()")}} and the {{domxref("CanvasRenderingContext2D.lineDashOffset", "lineDashOffset")}} property (Firefox bug 768067).
The
typeMustMatchattribute has been implemented on the {{domxref("HTMLObjectElement")}} interface (Firefox bug 827160).The
copyFromChannel()andcopyToChannel()methods have been added to {{domxref("AudioBuffer")}} (Firefox bug 915524).Event.isTrusted()is now unforgeable (Firefox bug 637248).The WebRTC API's {{domxref("RTCIceCandidate")}} object now includes a {{domxref("RTCIceCandidate.toJSON", "toJSON()")}} method to help with signaling and debugging (Firefox bug 928304).
The {{domxref("Navigator.vibrate()")}} method has been adapted to match the final specification: It now returns
falsewhen the list is too long or has too large entries, instead of throwing (Firefox bug 884935).As part of the ongoing effort to standardize global objects, the non-standard stylesheet change event interfaces, including
StyleRuleChangeEvent,StyleSheetApplicableStateChangeEventandStyleSheetChangeEvent, are no longer available from Web content. TheCSSGroupRuleRuleListinterface, the implementation detail of {{domxref("CSSRuleList")}}, has also been removed (Webkit bug 872934 and Firefox bug 916871).atobnow ignores whitespaces (Firefox bug 711180).WebGL:
MOZ_prefixed extension strings are deprecated. Support for them will be removed in the future. Use unprefixed extension string only. To get draft extensions, set thewebgl.enable-draft-extensionspreferences (Firefox bug 924176).
MathML
No change.
SVG
Blending of SVG elements using the {{cssxref("mix-blend-mode")}} property has been implemented. The
layout.css.mix-blend-mode.enabledpreference must be set totrue(Firefox bug 902525).
Changes for addon and Mozilla developers
The
downloads-indicatorbutton has gone away. You should now use thedownloads-buttonelement. If you need to check that it has loaded its overlay, check for theindicatorattribute on that button.The
chrome://browser/skin/downloads/indicator.cssstylesheet is no longer referenced in Firefox.
Security
TLS 1.2 has been implemented for improved security (Webkit bug 861266).
See also
List of changes in Marionette for Firefox 27.
Older versions
{{Firefox_for_developers('26')}}