JavaScript Feature Reference: Object Destructuring Syntax Web Browser Support Test

Last reviewed/updated: 06 Mar 2018 | Published: 29 Jan 2018 | Status: Active
Web browser support: Internet Explorer 10+, Edge 12+, Firefox 6+, Chrome 30+, Opera 17+

1. Introduction

In this web page there is one web browser JavaScript feature support test: a feature implementation test. The implementation test determines if the web browser recognizes the JavaScript object destructuring syntax. The implementation test is a simple test for the presence of web browser support, and a definitive test for the absence of web browser support. If the web browser does not recognize the JavaScript object destructuring syntax, the implementation test reports: Fail (no support): The web browser does not recognize the JavaScript object destructuring syntax. The web browser does not support the JavaScript object destructuring syntax. If the web browser recognizes the JavaScript object destructuring syntax, the implementation test reports: Pass (at least partial/possibly full support): The web browser recognizes the JavaScript object destructuring syntax. The web browser at least partially/possibly fully supports the JavaScript object destructuring syntax. Positive determination of full web browser support is beyond the scope of this test.

The web browser support test source code is shown in Section 2.1. The web browser support test source code is run in Section 2.2, which shows the web browser support test result.

1.1. Object Destructuring Syntax Web Browser Support

  • Pass (at least partial/possibly full support): ED14+, FF47+, CH49+, OP36+.
  • Fail (no support): IE11-, SF5.1.7-.

1.2. Abbreviations

  • IE = Internet Explorer.
  • ED = Edge Legacy 12 - 18 (EdgeHTML based) and Edge 79+ (Chromium based).
  • FF = Firefox.
  • SF = Safari.
  • CH = Chrome.
  • OP = Opera.

2. Object Destructuring Syntax Web Browser Support Test

2.1. Web Browser Support Test Source Code

<p id='testId'><b>Fail</b> (no support): The web browser does not recognize the JavaScript object destructuring syntax. The web browser does not support the JavaScript object destructuring syntax.</p><!-- Hard code Fail because web browser no support error stops JavaScript execution. -->

<script>
var objectLiteralOne = {propertyOne: 1, propertyTwo: 2};
var {propertyOne, propertyTwo} = objectLiteralOne; // Object literal variable as initializer.
var objectLiteralTwo = {propertyThree: 3, propertyFour: 4, propertyFive: null, propertySix: undefined};
var {propertyThree, propertyFour = "propertyFour default value not used", propertyFive = "propertyFive default value not used", propertySix = "propertySix default value used", propertySeven = "propertySeven default value used", propertyEight} = objectLiteralTwo; // Assign default value. Default value is used when initializer property value is undefined or initializer property does not exist.
var {propertyNine, propertyTen} = {propertyNine: 9, propertyTen: 10}; // Object literal as initializer.
({propertyEleven, propertyTwelve} = {propertyEleven: 11, propertyTwelve: 12}); // No var keyword. Place destructuring assignment statement inside ().
var objectLiteralThree = {propertyThirteen: 13, propertyFourteen: 14};
var {propertyThirteen: propertyX, propertyFourteen: propertyY} = objectLiteralThree; // Assign to variable with different name.
if ((propertyOne === 1) && (propertyTwo === 2) && (propertyThree === 3) && (propertyFour === 4) && (propertyFive === null) && (propertySix === "propertySix default value used") && (propertySeven === "propertySeven default value used") && (propertyEight === undefined) && (propertyNine === 9) && (propertyTen === 10) && (propertyEleven === 11) && (propertyTwelve === 12) && (propertyX === 13) && (propertyY === 14)){
 var element = document.getElementById("testId");
 element.innerHTML = "<b>Pass</b> (at least partial/possibly full support): The web browser recognizes the JavaScript object destructuring syntax. The web browser at least partially/possibly fully supports the JavaScript object destructuring syntax. Positive determination of full web browser support is beyond the scope of this test.";
}
</script>

2.2. Web Browser Support Test Result

Fail (no support): The web browser does not recognize the JavaScript object destructuring syntax. The web browser does not support the JavaScript object destructuring syntax.


3. Resources And Additional Information