Lesson 10, Thursday, 2022-10-19
for (let i = 0; i <= 10; i++) {
console.log(i);
}
- What's the result?
0 1 2 3 4 5 6 7 8 9 10
const colors = ['red', 'green', 'blue', 'yellow'];
let i = 0;
while (i < colors.length) {
console.log(colors[i]);
i++;
}
- What's the result?
red green blue yellow
for (let i = 0; i <= 10; i--) {
console.log(i);
}
- What's the result?
let i = 10;
while (i < 20) {
console.log(i);
}
- What's the result?
- We use a
for
loop if we know in advance how often it will be executed.
for (let i = 0; i < 1000; i++) {
console.log(i);
}
- We use a
while
loop if we don't know how many times the loop will be executed.
while (isHungry) {
eat();
}
// string
let name = "Hasan";
// number
let age = 24;
// boolean
let isProgrammer = true;
// undefined
let doNotKnow;
// object
let person = {
firstName: "Konrad",
lastName: "Zuse",
dateOfBirth: "22 June 1910",
profession: "inventor",
achievement: "world's first programmable computer"
};
Let's imagine you need to describe three friends:
let friend1Name = "Alice";
let friend1Age = 30;
let friend2Name = "Bob";
let friend2Age = 35;
let friend3Name = "Carol";
let friend3Age = 42;
We need a lot of variables.
Now imagine a function that operates on 2 people:
function introduce(person1Name, person1Age, person2Name, person2Age) {
console.log("Hello, I am " + person1Name + ", I am " + person1Age + " years old.");
console.log("Hello" + person1Name + ", my name is " + person2Name + ", I am " + person2Age + " years old.");
}
The parameter list gets rather long, and if you'd like to introduce another variable, it gets messy.
Wouldn't it be nicer if we could group information that belongs together somehow?
An object, in Javascript, is a group of key / value pairs
We can think of key/value pairs as words in a dictionary
- a word is the key
- the definition is the value
Basic example of an object
let person = {
firstName: 'Owen',
age: 30,
isProgrammer: true
};
key/value pairs are also referred to as properties
let person = {
firstName: 'Owen', // comma
age: 30, // comma
isProgrammer: true // comma is optional
};
- can you name all the properties in this person object?
- and its keys?
- and its values?
let book = {
title: 'The Lord of the Rings',
author: 'J. R. R. Tolkien',
publicationYear: 1954,
pages: 1216
};
let car = {
make: 'Volkswagen',
model: 'Golf',
modelYear: 2005,
};
Define a variable called me
and initialize it with an object containing the following information about you:
- name
- favorite food
- hair color
- eye color
Now we know how to create objects, what can we do with it?
let friend = {
name: "Alice",
age: 30
};
// we can access the value of a property using the "." operator
let friendName = friend.name; // friendName points to "Alice"
console.log(friendName + " is my friend.");
// we can also change the value
friend.age = 31;
console.log("She is " + friend.age + " years old.")
let book = {
title: 'The Lord of the Rings',
author: 'J. R. R. Tolkien',
publicationYear: 1954,
pages: 1216
};
console.log(book.title + " was written by " + book.author);
let car = {
make: 'Volkswagen',
model: 'Golf',
modelYear: 2005,
};
if (car.modelYear > 2000) {
console.log('The car is relatively modern.')
} else {
console.log('The car is rather old.')
}
Start with the me
object you created in the earlier task that contains your name and favorite food.
Write a function that takes that object as a parameter and introduces that person using console.log
.
Example output:
introducePerson(me);
// "Hi, my name is Owen and my favorite food is curry"
Now create another object called friend
with the same properties as me
.
Introduce your friend using the same function you created in part 1.
Example output:
introducePerson(friend);
// "Hi, my name is Harald and my favorite food is pizza"
Create a function that takes two "person" objects. Compare their ages, then use console.log
to print who is older of the two.
You may need to first add an "age" property to your objects if you don't have it already.
Example output:
whoIsOlder(me, friend);
// "Harald is older"
So objects consist of key-value pairs (also called properties).
Keys point to values.
let me = {
firstName: 'Owen',
age: 30,
isProgrammer: true
};
So far, we've used strings, numbers, and booleans as possible values. What else could we use?
let me = {
firstName: "Owen",
address: {
street: "Invalidenstraße",
city: "Berlin"
}
};
How many properties does the object above have? How can you access the city
in the me
variable above?
let myCity = me.address.city;
let me = {
name: "Harald",
greeting: function() {
if (dayOfWeek === "Monday") {
return "Get out of my face";
} else {
return "Hi, how are you?";
}
}
};
How would you call the greeting function?
let greeting = me.greeting();
A function inside an object is also called method:
// I am a function!
function sayHi() {
return "Hi!";
}
let me = {
// I'm a method!
sayHi: function() {
return "Hi!";
}
};
You've been using objects and methods this whole time!
console
is a "global" object, and log
is a method belonging to console
.
Using your "me" object, create a method to introduce yourself (using console.log). Create a object within that represents your address.
me.introduce();
// "Hi, my name is Owen"
console.log(me.address.city); // "Berlin"
console.log(me.address.country); // "Germany"