-
-
Notifications
You must be signed in to change notification settings - Fork 84
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
NW-6 | AREEB-SATTAR | JS3| [TECH ED] Array Destructuring | WEEK-3 #306
base: main
Are you sure you want to change the base?
Changes from all commits
895c60d
a8d2cd6
802c06d
905a6bc
38403fb
0029a67
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Great use of destructuring, Areeb! |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,3 +6,13 @@ let order = [ | |
{ itemName: "Hot Coffee", quantity: 2, unitPrice: 1.0 }, | ||
{ itemName: "Hash Brown", quantity: 4, unitPrice: 0.4 }, | ||
]; | ||
|
||
let sum = 0; | ||
|
||
order.forEach(({ itemName, quantity, unitPrice }) => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Excellent! |
||
let total = unitPrice * quantity; | ||
console.log(`For ${quantity} ${itemName} the total price is ${total}`); | ||
sum += total; | ||
}); | ||
|
||
console.log(`Total: ${+sum}`); |
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There's two files from the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I did realize this later, I will try to be more careful with this in future |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,96 +1,56 @@ | ||
<!DOCTYPE html> | ||
<html> | ||
<head> | ||
<title> </title> | ||
<meta | ||
charset="utf-8" | ||
name="viewport" | ||
content="width=device-width, initial-scale=1.0" | ||
/> | ||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script> | ||
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.16.0/umd/popper.min.js"></script> | ||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js"></script> | ||
<link | ||
rel="stylesheet" | ||
href="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" | ||
/> | ||
<link rel="stylesheet" type="text/css" href="style.css" /> | ||
</head> | ||
|
||
<body> | ||
<div class="jumbotron text-center"> | ||
<h1>Library</h1> | ||
<p>Add books to your virtual library</p> | ||
</div> | ||
<head> | ||
<title> Book Library</title> | ||
<meta charset="utf-8" name="viewport" content="width=device-width, initial-scale=1.0" /> | ||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script> | ||
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.16.0/umd/popper.min.js"></script> | ||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js"></script> | ||
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" /> | ||
<link rel="stylesheet" type="text/css" href="style.css" /> | ||
</head> | ||
|
||
<body> | ||
<div class="jumbotron text-center"> | ||
<h1>Library</h1> | ||
<p>Add books to your virtual library</p> | ||
</div> | ||
|
||
<button data-toggle="collapse" data-target="#demo" class="btn btn-info"> | ||
Add new book | ||
</button> | ||
<button type="button" data-toggle="collapse" data-target="#demo" class="btn btn-info"> | ||
Add new book | ||
</button> | ||
|
||
<div id="demo" class="collapse"> | ||
<div class="form-group"> | ||
<label for="title">Title:</label> | ||
<input | ||
type="title" | ||
class="form-control" | ||
id="title" | ||
name="title" | ||
required | ||
/> | ||
<label for="author">Author: </label> | ||
<input | ||
type="author" | ||
class="form-control" | ||
id="author" | ||
name="author" | ||
required | ||
/> | ||
<label for="pages">Pages:</label> | ||
<input | ||
type="number" | ||
class="form-control" | ||
id="pages" | ||
name="pages" | ||
required | ||
/> | ||
<label class="form-check-label"> | ||
<input | ||
type="checkbox" | ||
class="form-check-input" | ||
id="check" | ||
value="" | ||
/>Read | ||
</label> | ||
<input | ||
type="submit" | ||
value="Submit" | ||
class="btn btn-primary" | ||
onclick="submit();" | ||
/> | ||
</div> | ||
<div id="demo" class="collapse"> | ||
<div class="form-group"> | ||
<label for="title">Title:</label> | ||
<input type="text" class="form-control" id="title" name="title" required /> | ||
<label for="author">Author: </label> | ||
<input type="text" class="form-control" id="author" name="author" required /> | ||
<label for="pages">Pages:</label> | ||
<input type="number" class="form-control" id="pages" name="pages" required /> | ||
<label class="form-check-label"> | ||
<input type="checkbox" class="form-check-input" id="check" value="" />Read | ||
</label> | ||
<input type="submit" value="Submit" class="btn btn-primary" onclick="submit();" /> | ||
</div> | ||
</div> | ||
|
||
<table class="table" id="display"> | ||
<thead class="thead-dark"> | ||
<tr> | ||
<th>Title</th> | ||
<th>Author</th> | ||
<th>Number of Pages</th> | ||
<th>Read</th> | ||
<th>Delete</th> | ||
</tr> | ||
</thead> | ||
<tbody> | ||
</tbody> | ||
</table> | ||
|
||
<table class="table" id="display"> | ||
<thead class="thead-dark"> | ||
<tr> | ||
<th>Title</th> | ||
<th>Author</th> | ||
<th>Number of Pages</th> | ||
<th>Read</th> | ||
<th></th> | ||
</tr> | ||
</thead> | ||
<tbody> | ||
<tr> | ||
<td></td> | ||
<td></td> | ||
<td></td> | ||
<td></td> | ||
<td></td> | ||
</tr> | ||
</tbody> | ||
</table> | ||
<script src="script.js"></script> | ||
</body> | ||
|
||
<script src="script.js"></script> | ||
</body> | ||
</html> | ||
</html> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this would be a good time to introduce a new way to use destructuring. This function takes a parameter that is an object. We know the object will be a person that has a name, age, and favourite food.
Because we know exactly what information we need from the object, we can destructure it right here as we define the function.
function introduceYourself({ name, age, favouriteFood })
will give us thename
,age
, andfavouriteFood
to use inside of the function block.Every time we pass a person object to the function, the code will now magically extract those properties from the object without us doing any extra work! 🚀
Let me know if that makes sense @areebsattar
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for this explanation, it does make it clearer and I believe what we were doing with props in React also made it clearer as well.