Using Arrow Functions

Modern JavaScript Incorporating Functions
10 minutes
Share the link to this page
Copied
  Completed
You need to have access to the item to view this lesson.
One-time Fee
$99.99
List Price:  $139.99
You save:  $40
€94.79
List Price:  €132.71
You save:  €37.92
£78.97
List Price:  £110.56
You save:  £31.59
CA$139.89
List Price:  CA$195.85
You save:  CA$55.96
A$153.73
List Price:  A$215.23
You save:  A$61.50
S$134.32
List Price:  S$188.05
You save:  S$53.73
HK$778.26
List Price:  HK$1,089.59
You save:  HK$311.33
CHF 88.57
List Price:  CHF 124
You save:  CHF 35.43
NOK kr1,105.08
List Price:  NOK kr1,547.16
You save:  NOK kr442.07
DKK kr706.99
List Price:  DKK kr989.82
You save:  DKK kr282.82
NZ$170.06
List Price:  NZ$238.10
You save:  NZ$68.03
د.إ367.26
List Price:  د.إ514.17
You save:  د.إ146.91
৳11,906.24
List Price:  ৳16,669.22
You save:  ৳4,762.97
₹8,436.24
List Price:  ₹11,811.08
You save:  ₹3,374.83
RM447.10
List Price:  RM625.96
You save:  RM178.86
₦167,464.25
List Price:  ₦234,456.65
You save:  ₦66,992.40
₨27,687.73
List Price:  ₨38,763.93
You save:  ₨11,076.20
฿3,470.35
List Price:  ฿4,858.63
You save:  ฿1,388.28
₺3,445.98
List Price:  ₺4,824.51
You save:  ₺1,378.53
B$578.68
List Price:  B$810.17
You save:  B$231.49
R1,810.53
List Price:  R2,534.81
You save:  R724.28
Лв185.34
List Price:  Лв259.49
You save:  Лв74.14
₩139,691.42
List Price:  ₩195,573.58
You save:  ₩55,882.15
₪373.67
List Price:  ₪523.15
You save:  ₪149.48
₱5,901.36
List Price:  ₱8,262.14
You save:  ₱2,360.78
¥15,574.86
List Price:  ¥21,805.43
You save:  ¥6,230.57
MX$2,020.46
List Price:  MX$2,828.72
You save:  MX$808.26
QR363.35
List Price:  QR508.71
You save:  QR145.35
P1,355.53
List Price:  P1,897.79
You save:  P542.26
KSh12,948.70
List Price:  KSh18,128.70
You save:  KSh5,180
E£4,969.50
List Price:  E£6,957.50
You save:  E£1,988
ብር12,262.61
List Price:  ብር17,168.15
You save:  ብር4,905.53
Kz91,256.94
List Price:  Kz127,763.36
You save:  Kz36,506.42
CLP$97,119.28
List Price:  CLP$135,970.88
You save:  CLP$38,851.60
CN¥724.58
List Price:  CN¥1,014.45
You save:  CN¥289.86
RD$6,000.34
List Price:  RD$8,400.72
You save:  RD$2,400.37
DA13,341.73
List Price:  DA18,678.95
You save:  DA5,337.22
FJ$227.04
List Price:  FJ$317.87
You save:  FJ$90.82
Q769.16
List Price:  Q1,076.85
You save:  Q307.69
GY$20,834.51
List Price:  GY$29,169.15
You save:  GY$8,334.63
ISK kr13,772.62
List Price:  ISK kr19,282.22
You save:  ISK kr5,509.60
DH995.44
List Price:  DH1,393.66
You save:  DH398.21
L1,819.82
List Price:  L2,547.83
You save:  L728
ден5,825.40
List Price:  ден8,155.79
You save:  ден2,330.39
MOP$798.74
List Price:  MOP$1,118.27
You save:  MOP$319.52
N$1,801.35
List Price:  N$2,521.97
You save:  N$720.61
C$3,666.61
List Price:  C$5,133.40
You save:  C$1,466.79
रु13,462.23
List Price:  रु18,847.67
You save:  रु5,385.43
S/378.10
List Price:  S/529.35
You save:  S/151.25
K400.90
List Price:  K561.28
You save:  K160.37
SAR375.38
List Price:  SAR525.55
You save:  SAR150.16
ZK2,752.36
List Price:  ZK3,853.42
You save:  ZK1,101.05
L471.69
List Price:  L660.38
You save:  L188.69
Kč2,395.79
List Price:  Kč3,354.20
You save:  Kč958.41
Ft38,840.72
List Price:  Ft54,378.57
You save:  Ft15,537.84
SEK kr1,099.74
List Price:  SEK kr1,539.68
You save:  SEK kr439.94
ARS$100,165.56
List Price:  ARS$140,235.79
You save:  ARS$40,070.23
Bs690.96
List Price:  Bs967.37
You save:  Bs276.41
COP$440,690.82
List Price:  COP$616,984.78
You save:  COP$176,293.95
₡50,645.88
List Price:  ₡70,906.26
You save:  ₡20,260.37
L2,517.41
List Price:  L3,524.47
You save:  L1,007.06
₲775,966.15
List Price:  ₲1,086,383.66
You save:  ₲310,417.50
$U4,274.58
List Price:  $U5,984.58
You save:  $U1,710
zł411.21
List Price:  zł575.71
You save:  zł164.50
Already have an account? Log In

Transcript

ESX has established a new syntax for functions and is called arrow functions. It doesn't do away with the syntax, you've just learned that it's still very much viable. But the syntax used for arrow functions requires less typing. They're much more compact. And they also address another issue that was with functions that has to do with this keyword, something we haven't talked about yet. But those are the two reasons that arrow functions were developed in ESX.

Now, should you switch to arrow functions? Well, let me first introduce arrow functions to you. And then we'll have a discussion about when you might want to use them. So let's take a look at this new syntax. So here is a function This is a function expression is simply adds two numbers together and returns the results. This is our regular syntax for the function.

Now how would this exact same function be defined using arrow functions. Let's take a look at that. This one line is the same function using an arrow function. And you can see why they call it arrow functions. It uses equal sign and then a greater than operator to create an arrow. Now let's look at the parts of this arrow function.

So all arrow functions are function expressions. So in this case, it's part of an expression that is assigning the function to a variable sum just like we had up here. Notice we can skip the function key word That is gone. In fact, it's replaced with the arrow. We still have the parentheses if we want to pass in arguments, and so we have to designate the parameters inside of parentheses. Then we have the arrow.

And the arrow accomplishes a couple of things. It identifies it as a function. But it also, since there's only a single line here, it says to return the results of this statement number one plus number two. And so there's two things we've been able to eliminate with arrow functions, the function keyword, and the return keyword. And they're all replaced with the arrow. Now the curly braces don't exist as well, but we could have curly braces with the arrow function.

When there's only a single statement. The curly braces are not necessary and therefore I've eliminated them in this example. So both of these functions return the same thing. All right, let's look at a few additional examples of arrow functions. It's good to know these other examples as well, because you may encounter them in other people's code, or you may choose to use them in your own. So this next function, this next arrow function, it takes a number as an argument, and it just multiplies the number by itself and returns the results.

So we've set the function to the variable func one. And notice since we only have one parameter in the function, we can eliminate the parentheses as well. So even more simplified approach. However, sometimes I think the more simplified we get the more difficult it can be to read it. If you were looking through a bunch of code, you'd have to stop and examine this to realize, Oh, this is a function. And so I don't think that's always the best is to simplify it so much.

But that's just my opinion. But anyway, we have one parameter, one argument being passed in, so we can eliminate the parentheses. Then we have the arrow and that says to return the results of num multiplied by num. All right, let's look at another example. This example has nothing being passed in so there's no parameters necessary for the function. However, when there's nothing being passed in the parentheses are required.

And so this function simply returns the number 100. That's all it does. All right, let's look at one more example that uses curly braces with the arrow function. And then we'll talk about when you may want to use these. Because there is more than one line in the code block, curly braces are required. So this function is simply allows you to pass in a number and pass in a percent, and then it returns the percent of the number you passed in.

That's all it does. So we're passing in a number of percent, and then the arrow defines the function inside the braces is the code block. We set percent equal to percent divided by 100. And then we return num times percent. Now notice that when you have the braces and you have multiple lines, you do have to use the return keyword To return the value when you have a single statement, then the arrow function will automatically return the results. Otherwise you do need to read, you do need to include the return keyword.

So there are some example of arrow functions. Now, when would you use them? Well, I think in really large functions, I think they're a little more complex, a little harder to read, and so forth. In large functions, I would use the traditional method of defining that function where arrow functions and their simplified syntax may be very helpful as with anonymous functions, we just talked about high order functions and how we can pass functions into other functions. Well, that's a great candidate for arrow functions because it simplifies the syntax and therefore is easier to Read a simplified syntax being passed into another function. So that might be a situation where where arrow functions are helpful arrow functions I mentioned also addressed another problem which has been found with traditional function def definitions.

That problem is a bit more complex. It has to do with this binding complications that can occur with traditional functions. We have not discussed that in this Getting Started course. So I don't want to confuse the issue by addressing it here with arrow functions. So the main purpose of introducing arrow functions to you is so that when you see it in code, you will recognize it. And you can use this alternative syntax and in places where it makes sense.

Now we've looked at several examples. Let's see those examples executed within JavaScript page. Now, let me jump out to sublime. I've already entered all this information, so you don't have to watch me type it in. So we have our sum function, our traditional function that we started with. We then converted that to an arrow function where it's adding two numbers, I gave it a different variable name, so that we could address both of them separately.

And then we have the next two examples, where we're passing in a number and multiplying it by itself. And then the one that simply returns 100. And then we have the percent example that uses the curly braces. Alright, I have a console dot log. And inside that console dot log statement, I call each of those functions so that I can simply log out the value that those functions return. So let me go ahead and run that.

And then we'll compare it with those examples. Open up the console, I'm going to jump back to sublime. And I'm going to reduce the size of sublime a bit so we can see what's happening. So, in the first console dot log statement, I call this um function passed and a five and a six that returned 11 with the arrow function, returning the exact same thing. Then I called function one with a 10. And that simply multiplies the number by itself that came back with 100.

And then func two simply returns 100. That's all it does. So nothing crazy with that particular function, and then finally called the percent function I passed in the number 100. And the percentage I wanted to take was 10. And it returns a 10 10% of 100 is 10. So there we can see the arrow functions working.

In one of the exercises, I'll have you do an arrow function as a part of a higher order function that will give you a chance to use that syntax and get used to it. It's important to be aware of the syntax so that you can identify it and also because you may want to use it in certain places. Remember arrow functions are ESX ACMA script six standard. They are supported by latest versions of all modern browsers, and by node. So if your requirements for the project you're working on will match that you could use these function definitions. All right, let's move on to the exercises for functions.

Sign Up

Share

Share with friends, get 20% off
Invite your friends to LearnDesk learning marketplace. For each purchase they make, you get 20% off (upto $10) on your next purchase.