# Advanced techniques in destructuring (How to destructure arrays and objects - Part 3)

There are advanced techniques used in destructuring to help us write even cleaner code, from the last two articles, we discussed how destructuring arrays and objects works.

In this article we'll be looking at ways to take destructuring in JavaScript a step further. If any of the techniques seem strange to you, I'd suggest you read the last two parts 👌, let's dive in shall we?

<center>
<img 
alt="a man diving into water"
src="https://giphygifs.s3.amazonaws.com/media/KQmKXYG0Ly4zm/giphy.gif"/></center>


## How to destructure function parameters
This technique is very popular, especially when working with objects being passed as arguments to a function.

### Destructuring function parameters in objects

Say we had an object `man` with some properties:
```javascript
const man = {
  name: 'Johny',
  age: 50,
  hairColor: 'black'
}
```
If we needed to get specific details about 'man' when the object is passed as an argument: 

```javascript
function getName({name}){
  return name;
}

getName(man); // 'Johny'
getName({name: 'Sandy', age:24}); // 'Sandy'
```
**Note:** the name of the key you want to destructure must match the variable name you use, to change the name, set an alias (*see part 2*).

### Doing the same for arrays
It's possible to destructure arrays passed to functions as arguments too: 
```javascript
const friends= ['Mike', 'Bill', 'Jill', 'Max'];
function getBestFriend ([friendOne]){
return friendOne;
}
getBestFriend(friends); // 'Mike'
```
so we're taking the first friend from the array of friends and returning it as the best friend.

**It's also possible to use the rest parameter `...` to assign the remaining elements to another variable.**

## Nested destructuring

It's possible to get properties that are several levels deep in an object or value in an array:

### Nested object destructuring

If we need to get a nested property in an object, this is how it would be:

```javascript
const user = {
  name: 'Naira Marley',
  age: 12,
  socialMedia: {
    twitter: '@officialnairam1'
  }
}

function getTwitter({ socialMedia:{twitter} }){
  return twitter;
}

getTwitter(user); // '@officialnairam1'

```

### Nested array destructuring

It is also possible to get values from nested arrays

```javascript
const colours = ['#000000', [255, 0, 0] , '#ffffff'];

function getRed([hex_black, [rgb_red, , ], hex_white]){
  return rgb_red;
}

getRed(colours);

```
_Notice how i skipped the other rgb values?_

## Declaring variables before use
It's possible to declare variables before use, however, there is one gotcha with using this technique when destructuring objects, lucky for us, there's a workaround which we'll see soon.

### Declaring variables before use in arrays

```javascript
let white, black, green, yellow;

[white, black, green, yellow] = ['#ffffff', '#000000','#1ed947', '#fff829'];

console.log(green); // '#1ed947'
```
You are not permitted to cop
You can also assign default values:
```javascript
let white, black, green;
let yellow = 'yellow';
[white, black, green] = ['#ffffff', '#000000','#1ed947', '#fff829'];

console.log(yellow); // 'yellow'
```
### Declaring variables before use in objects
```javascript
let firstName = 'Post';
let lastName = 'Malone';
let country = 'U.S.A';

let firstName, lastName, country;

let user = {
  firstName: 'Zlatan',
  lastName: 'Ibile',
  country: 'Nigeria'
};

({ firstName, lastName, country } = user);

console.log(firstName); // 'Zlatan'

```

Notice how we used a pair of enclosing parentheses `()`? that's because if we didn't, JavaScript will see that line as a block expression and code blocks do not appear on the left hand side of an assignment. An error would've been thrown. 

## Mixed destructuring
You thought that was all? nah, not even close, we can even go further to destructure arrays nested in objects and vice versa. Take a look at this object:
```javascript
const user = {
  name: 'Janet',
  age: 23,
  sports: ['basketball', 'hockey', 'soccer']
}

const {name, sports: [firstSport, , lastSport]} = user;

console.log(firstSport); //basketball
```

To read further on destructuring, check out this page on the [Mozilla Developer Network](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Destructuring_assignment).

