Understanding Arguments and Parameters

Modern JavaScript Incorporating Functions
8 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

Another feature of functions which make them extremely useful is that you can pass arguments into that function. those arguments are collected by the parameters which you define in the function. And then you can use those parameters as the variables which they are as part of the code, which makes up the function. Let's take a look at some examples of how that would be done. So first with an example using a function declaration. We set up the parameters this way, we have the function keyword, then the function name then inside of parentheses we enter the number number of parameters which we want to accept.

Then we have curly braces, and then the code block to execute using pram, one pram two which merely act as variables. And then the end of the curly brace Let's look how a functional function expression would handle the same thing. So as you probably guessed, it's exactly the same except we're assigning the whole thing to a variable, in this case, variable x. Now when we call both of these, this is what it would look like. For the function declaration, we would use the function name and inside of parentheses, we would pass in the two arguments for the function expression, the variable with parentheses and inside of the parentheses, the two arguments. Alright, let's jump to sublime and do a concrete example of this.

So what we want to do is create a function that will sum to numbers, so really not too difficult. Let's go ahead and define our function, I'm going to use a function expression. The variable name will be some set that equal to function. And then inside of parentheses, I want to set up my parameters num one, and m two, we're going to pass in two numbers, and then we will sum those numbers and print the results to the console. Now curly braces, and since this is a, an expression, I should put a semicolon at the end. All right, I'm going to declare a variable.

Set it equal to zero. This part's not necessary. I could just console dot log, those two numbers added together, but I'm going to assign the sum to a variable first. Equals number one plus number two. And then we console dot log, the total. All right, that's our function.

Now let's call our function. Let's do, let's call it twice. The arguments that we're passing in on the first example is five are five and six. The arguments for the second example are 100 and negative four. All right, let's see what the results are. Open the console.

And we have an 11 and a 96. printed out so that worked great. Now what happens if we only pass in one argument? Now in some languages, this would cause an error in JavaScript it does not. And because it doesn't throw an error because only one argument is passed in, it could cause bugs that might be hard to figure out. Let's first see what the results are when we just pass in one argument, jump back refresh, open the console. And it tells us any n it displays any n meaning something that was not a number was a you was used as a part of that operation.

And obviously, one of the parameters was undefined, num two was undefined. And so num two, when it was added to num one caused the Nn. So how can we deal with this? Well, first I'm going to show you how we have dealt with it This type of thing in the past, then I'll show you a solution that comes from es six. And the solution from ESX is supported by the latest version of all modern browsers and also node. So prior to ESX, this is what we would need to do.

I'm going to set num one equal to and then in parentheses, we're going to use a conditional num one not equal to undefined. So if num one is not equal to undefined, then we're going to use a shortened version of the if conditional may remember this from a previous movie. So if num one is not equal to undefined, then we will put num one into num one else. We will put zero into number one. Okay. So let me just walk through this really quick.

So the conditionals simply checks to see if num one is not equal to undefined. If only one argument is passed in is possible one of these could be undefined. If they're undefined, it will do the outs portion and set num one equal to zero. If it's not undefined, it will set num one equal to the number one. So it ends up with what was passed in. All right, let's do the same thing for num to our conditional.

Not equal to undefined. Question mark. If this evaluates to true, num to his return, else if it evaluates to false, zero, his return. All right, let's see what that does for the problem we were experiencing. Save that jump out and refresh, open the console. And it worked this time.

So One number was passed in and assumed the other number would be zero. Now that's a decision we make as a programmer what this other number will be. In this case, I'm assuming it will be zero if they do not pass something else in. All right, now let's look at the ESX solution. Now, as mentioned, this is supported by the latest versions of all modern browsers, and node. I'm going to remove these lines here.

And this is what is possible. With es six, you can enter a default value for the parameter. So the way this works is, if num one has a value, it will use it if it does not, it will use zero. That's what this is telling it. Let's go ahead and save that. Refresh.

Open the console. And sure enough, that still works. Alright, so we looked at two solutions to the problem if we define a parameter and only and not all of the arguments are passed in. The second solution is only available with s six. The first solution is what's been done prior to ESX or something similar to that. Alright, let's move on to the next topic.

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.