typos & remove duplicate words

pull/957/head
aliwert 4 months ago
parent 3b3c002d78
commit 1f9ddf6d20

@ -7,10 +7,11 @@
<img alt="Twitter Follow" src="https://img.shields.io/twitter/follow/asabeneh?style=social"> <img alt="Twitter Follow" src="https://img.shields.io/twitter/follow/asabeneh?style=social">
</a> </a>
<sub>Author: <sub>Author:
<a href="https://www.linkedin.com/in/asabeneh/" target="_blank">Asabeneh Yetayeh</a><br> <a href="https://www.linkedin.com/in/asabeneh/" target="_blank">Asabeneh Yetayeh</a><br>
<small> January, 2020</small> <small> January, 2020</small>
</sub> </sub>
</div> </div>
[<< Day 2](../02_Day_Data_types/02_day_data_types.md) | [Day 4 >>](../04_Day_Conditionals/04_day_conditionals.md) [<< Day 2](../02_Day_Data_types/02_day_data_types.md) | [Day 4 >>](../04_Day_Conditionals/04_day_conditionals.md)
@ -18,38 +19,38 @@
![Thirty Days Of JavaScript](../images/banners/day_1_3.png) ![Thirty Days Of JavaScript](../images/banners/day_1_3.png)
- [📔 Day 3](#-day-3) - [📔 Day 3](#-day-3)
- [Booleans](#booleans) - [Booleans](#booleans)
- [Truthy values](#truthy-values) - [Truthy values](#truthy-values)
- [Falsy values](#falsy-values) - [Falsy values](#falsy-values)
- [Undefined](#undefined) - [Undefined](#undefined)
- [Null](#null) - [Null](#null)
- [Operators](#operators) - [Operators](#operators)
- [Assignment operators](#assignment-operators) - [Assignment operators](#assignment-operators)
- [Arithmetic Operators](#arithmetic-operators) - [Arithmetic Operators](#arithmetic-operators)
- [Comparison Operators](#comparison-operators) - [Comparison Operators](#comparison-operators)
- [Logical Operators](#logical-operators) - [Logical Operators](#logical-operators)
- [Increment Operator](#increment-operator) - [Increment Operator](#increment-operator)
- [Decrement Operator](#decrement-operator) - [Decrement Operator](#decrement-operator)
- [Ternary Operators](#ternary-operators) - [Ternary Operators](#ternary-operators)
- [Operator Precedence](#operator-precedence) - [Operator Precedence](#operator-precedence)
- [Window Methods](#window-methods) - [Window Methods](#window-methods)
- [Window alert() method](#window-alert-method) - [Window alert() method](#window-alert-method)
- [Window prompt() method](#window-prompt-method) - [Window prompt() method](#window-prompt-method)
- [Window confirm() method](#window-confirm-method) - [Window confirm() method](#window-confirm-method)
- [Date Object](#date-object) - [Date Object](#date-object)
- [Creating a time object](#creating-a-time-object) - [Creating a time object](#creating-a-time-object)
- [Getting full year](#getting-full-year) - [Getting full year](#getting-full-year)
- [Getting month](#getting-month) - [Getting month](#getting-month)
- [Getting date](#getting-date) - [Getting date](#getting-date)
- [Getting day](#getting-day) - [Getting day](#getting-day)
- [Getting hours](#getting-hours) - [Getting hours](#getting-hours)
- [Getting minutes](#getting-minutes) - [Getting minutes](#getting-minutes)
- [Getting seconds](#getting-seconds) - [Getting seconds](#getting-seconds)
- [Getting time](#getting-time) - [Getting time](#getting-time)
- [💻 Day 3: Exercises](#-day-3-exercises) - [💻 Day 3: Exercises](#-day-3-exercises)
- [Exercises: Level 1](#exercises-level-1) - [Exercises: Level 1](#exercises-level-1)
- [Exercises: Level 2](#exercises-level-2) - [Exercises: Level 2](#exercises-level-2)
- [Exercises: Level 3](#exercises-level-3) - [Exercises: Level 3](#exercises-level-3)
# 📔 Day 3 # 📔 Day 3
@ -60,12 +61,12 @@ A boolean data type represents one of the two values:_true_ or _false_. Boolean
**Example: Boolean Values** **Example: Boolean Values**
```js ```js
let isLightOn = true let isLightOn = true;
let isRaining = false let isRaining = false;
let isHungry = false let isHungry = false;
let isMarried = true let isMarried = true;
let truValue = 4 > 3 // true let truValue = 4 > 3; // true
let falseValue = 4 < 3 // false let falseValue = 4 < 3; // false
``` ```
We agreed that boolean values are either true or false. We agreed that boolean values are either true or false.
@ -93,15 +94,15 @@ It is good to remember those truthy values and falsy values. In later section, w
If we declare a variable and if we do not assign a value, the value will be undefined. In addition to this, if a function is not returning the value, it will be undefined. If we declare a variable and if we do not assign a value, the value will be undefined. In addition to this, if a function is not returning the value, it will be undefined.
```js ```js
let firstName let firstName;
console.log(firstName) //not defined, because it is not assigned to a value yet console.log(firstName); //not defined, because it is not assigned to a value yet
``` ```
## Null ## Null
```js ```js
let empty = null let empty = null;
console.log(empty) // -> null , means no value console.log(empty); // -> null , means no value
``` ```
## Operators ## Operators
@ -111,8 +112,8 @@ console.log(empty) // -> null , means no value
An equal sign in JavaScript is an assignment operator. It uses to assign a variable. An equal sign in JavaScript is an assignment operator. It uses to assign a variable.
```js ```js
let firstName = 'Asabeneh' let firstName = "Asabeneh";
let country = 'Finland' let country = "Finland";
``` ```
Assignment Operators Assignment Operators
@ -125,44 +126,41 @@ Arithmetic operators are mathematical operators.
- Addition(+): a + b - Addition(+): a + b
- Subtraction(-): a - b - Subtraction(-): a - b
- Multiplication(*): a * b - Multiplication(_): a _ b
- Division(/): a / b - Division(/): a / b
- Modulus(%): a % b - Modulus(%): a % b
- Exponential(**): a ** b - Exponential(**): a ** b
```js ```js
let numOne = 4 let numOne = 4;
let numTwo = 3 let numTwo = 3;
let sum = numOne + numTwo let sum = numOne + numTwo;
let diff = numOne - numTwo let diff = numOne - numTwo;
let mult = numOne * numTwo let mult = numOne * numTwo;
let div = numOne / numTwo let div = numOne / numTwo;
let remainder = numOne % numTwo let remainder = numOne % numTwo;
let powerOf = numOne ** numTwo let powerOf = numOne ** numTwo;
console.log(sum, diff, mult, div, remainder, powerOf) // 7,1,12,1.33,1, 64
console.log(sum, diff, mult, div, remainder, powerOf); // 7,1,12,1.33,1, 64
``` ```
```js ```js
const PI = 3.14 const PI = 3.14;
let radius = 100 // length in meter let radius = 100; // length in meter
//Let us calculate area of a circle //Let us calculate area of a circle
const areaOfCircle = PI * radius * radius const areaOfCircle = PI * radius * radius;
console.log(areaOfCircle) // 314 m console.log(areaOfCircle); // 314 m
const gravity = 9.81; // in m/s2
const gravity = 9.81 // in m/s2 let mass = 72; // in Kilogram
let mass = 72 // in Kilogram
// Let us calculate weight of an object // Let us calculate weight of an object
const weight = mass * gravity const weight = mass * gravity;
console.log(weight) // 706.32 N(Newton) console.log(weight); // 706.32 N(Newton)
const boilingPoint = 100 // temperature in oC, boiling point of water
const bodyTemp = 37 // body temperature in oC
const boilingPoint = 100; // temperature in oC, boiling point of water
const bodyTemp = 37; // body temperature in oC
// Concatenating string with numbers using string interpolation // Concatenating string with numbers using string interpolation
/* /*
@ -172,7 +170,7 @@ const bodyTemp = 37 // body temperature in oC
*/ */
console.log( console.log(
`The boiling point of water is ${boilingPoint} oC.\nHuman body temperature is ${bodyTemp} oC.\nThe gravity of earth is ${gravity} m / s2.` `The boiling point of water is ${boilingPoint} oC.\nHuman body temperature is ${bodyTemp} oC.\nThe gravity of earth is ${gravity} m / s2.`
) );
``` ```
### Comparison Operators ### Comparison Operators
@ -183,38 +181,38 @@ In programming we compare values, we use comparison operators to compare two val
**Example: Comparison Operators** **Example: Comparison Operators**
```js ```js
console.log(3 > 2) // true, because 3 is greater than 2 console.log(3 > 2); // true, because 3 is greater than 2
console.log(3 >= 2) // true, because 3 is greater than 2 console.log(3 >= 2); // true, because 3 is greater than 2
console.log(3 < 2) // false, because 3 is greater than 2 console.log(3 < 2); // false, because 3 is greater than 2
console.log(2 < 3) // true, because 2 is less than 3 console.log(2 < 3); // true, because 2 is less than 3
console.log(2 <= 3) // true, because 2 is less than 3 console.log(2 <= 3); // true, because 2 is less than 3
console.log(3 == 2) // false, because 3 is not equal to 2 console.log(3 == 2); // false, because 3 is not equal to 2
console.log(3 != 2) // true, because 3 is not equal to 2 console.log(3 != 2); // true, because 3 is not equal to 2
console.log(3 == '3') // true, compare only value console.log(3 == "3"); // true, compare only value
console.log(3 === '3') // false, compare both value and data type console.log(3 === "3"); // false, compare both value and data type
console.log(3 !== '3') // true, compare both value and data type console.log(3 !== "3"); // true, compare both value and data type
console.log(3 != 3) // false, compare only value console.log(3 != 3); // false, compare only value
console.log(3 !== 3) // false, compare both value and data type console.log(3 !== 3); // false, compare both value and data type
console.log(0 == false) // true, equivalent console.log(0 == false); // true, equivalent
console.log(0 === false) // false, not exactly the same console.log(0 === false); // false, not exactly the same
console.log(0 == '') // true, equivalent console.log(0 == ""); // true, equivalent
console.log(0 == ' ') // true, equivalent console.log(0 == " "); // true, equivalent
console.log(0 === '') // false, not exactly the same console.log(0 === ""); // false, not exactly the same
console.log(1 == true) // true, equivalent console.log(1 == true); // true, equivalent
console.log(1 === true) // false, not exactly the same console.log(1 === true); // false, not exactly the same
console.log(undefined == null) // true console.log(undefined == null); // true
console.log(undefined === null) // false console.log(undefined === null); // false
console.log(NaN == NaN) // false, not equal console.log(NaN == NaN); // false, not equal
console.log(NaN === NaN) // false console.log(NaN === NaN); // false
console.log(typeof NaN) // number console.log(typeof NaN); // number
console.log('mango'.length == 'avocado'.length) // false console.log("mango".length == "avocado".length); // false
console.log('mango'.length != 'avocado'.length) // true console.log("mango".length != "avocado".length); // true
console.log('mango'.length < 'avocado'.length) // true console.log("mango".length < "avocado".length); // true
console.log('milk'.length == 'meat'.length) // true console.log("milk".length == "meat".length); // true
console.log('milk'.length != 'meat'.length) // false console.log("milk".length != "meat".length); // false
console.log('tomato'.length == 'potato'.length) // true console.log("tomato".length == "potato".length); // true
console.log('python'.length > 'dragon'.length) // false console.log("python".length > "dragon".length); // false
``` ```
Try to understand the above comparisons with some logic. Remembering without any logic might be difficult. Try to understand the above comparisons with some logic. Remembering without any logic might be difficult.
@ -233,23 +231,23 @@ The ! operator negates true to false and false to true.
```js ```js
// && ampersand operator example // && ampersand operator example
const check = 4 > 3 && 10 > 5 // true && true -> true const check = 4 > 3 && 10 > 5; // true && true -> true
const check = 4 > 3 && 10 < 5 // true && false -> false const check = 4 > 3 && 10 < 5; // true && false -> false
const check = 4 < 3 && 10 < 5 // false && false -> false const check = 4 < 3 && 10 < 5; // false && false -> false
// || pipe or operator, example // || pipe or operator, example
const check = 4 > 3 || 10 > 5 // true || true -> true const check = 4 > 3 || 10 > 5; // true || true -> true
const check = 4 > 3 || 10 < 5 // true || false -> true const check = 4 > 3 || 10 < 5; // true || false -> true
const check = 4 < 3 || 10 < 5 // false || false -> false const check = 4 < 3 || 10 < 5; // false || false -> false
//! Negation examples //! Negation examples
let check = 4 > 3 // true let check = 4 > 3; // true
let check = !(4 > 3) // false let check = !(4 > 3); // false
let isLightOn = true let isLightOn = true;
let isLightOff = !isLightOn // false let isLightOff = !isLightOn; // false
let isMarried = !false // true let isMarried = !false; // true
``` ```
### Increment Operator ### Increment Operator
@ -259,17 +257,17 @@ In JavaScript we use the increment operator to increase a value stored in a vari
1. Pre-increment 1. Pre-increment
```js ```js
let count = 0 let count = 0;
console.log(++count) // 1 console.log(++count); // 1
console.log(count) // 1 console.log(count); // 1
``` ```
1. Post-increment 1. Post-increment
```js ```js
let count = 0 let count = 0;
console.log(count++) // 0 console.log(count++); // 0
console.log(count) // 1 console.log(count); // 1
``` ```
We use most of the time post-increment. At least you should remember how to use post-increment operator. We use most of the time post-increment. At least you should remember how to use post-increment operator.
@ -281,17 +279,17 @@ In JavaScript we use the decrement operator to decrease a value stored in a vari
1. Pre-decrement 1. Pre-decrement
```js ```js
let count = 0 let count = 0;
console.log(--count) // -1 console.log(--count); // -1
console.log(count) // -1 console.log(count); // -1
``` ```
2. Post-decrement 2. Post-decrement
```js ```js
let count = 0 let count = 0;
console.log(count--) // 0 console.log(count--); // 0
console.log(count) // -1 console.log(count); // -1
``` ```
### Ternary Operators ### Ternary Operators
@ -300,15 +298,15 @@ Ternary operator allows to write a condition.
Another way to write conditionals is using ternary operators. Look at the following examples: Another way to write conditionals is using ternary operators. Look at the following examples:
```js ```js
let isRaining = true let isRaining = true;
isRaining isRaining
? console.log('You need a rain coat.') ? console.log("You need a rain coat.")
: console.log('No need for a rain coat.') : console.log("No need for a rain coat.");
isRaining = false isRaining = false;
isRaining isRaining
? console.log('You need a rain coat.') ? console.log("You need a rain coat.")
: console.log('No need for a rain coat.') : console.log("No need for a rain coat.");
``` ```
```sh ```sh
@ -317,15 +315,15 @@ No need for a rain coat.
``` ```
```js ```js
let number = 5 let number = 5;
number > 0 number > 0
? console.log(`${number} is a positive number`) ? console.log(`${number} is a positive number`)
: console.log(`${number} is a negative number`) : console.log(`${number} is a negative number`);
number = -5 number = -5;
number > 0 number > 0
? console.log(`${number} is a positive number`) ? console.log(`${number} is a positive number`)
: console.log(`${number} is a negative number`) : console.log(`${number} is a negative number`);
``` ```
```sh ```sh
@ -344,11 +342,11 @@ I would like to recommend you to read about operator precedence from this [link]
As you have seen at very beginning alert() method displays an alert box with a specified message and an OK button. It is a builtin method and it takes on argument. As you have seen at very beginning alert() method displays an alert box with a specified message and an OK button. It is a builtin method and it takes on argument.
```js ```js
alert(message) alert(message);
``` ```
```js ```js
alert('Welcome to 30DaysOfJavaScript') alert("Welcome to 30DaysOfJavaScript");
``` ```
Do not use too much alert because it is destructing and annoying, use it just to test. Do not use too much alert because it is destructing and annoying, use it just to test.
@ -358,12 +356,12 @@ Do not use too much alert because it is destructing and annoying, use it just to
The window prompt methods display a prompt box with an input on your browser to take input values and the input data can be stored in a variable. The prompt() method takes two arguments. The second argument is optional. The window prompt methods display a prompt box with an input on your browser to take input values and the input data can be stored in a variable. The prompt() method takes two arguments. The second argument is optional.
```js ```js
prompt('required text', 'optional text') prompt("required text", "optional text");
``` ```
```js ```js
let number = prompt('Enter number', 'number goes here') let number = prompt("Enter number", "number goes here");
console.log(number) console.log(number);
``` ```
### Window confirm() method ### Window confirm() method
@ -373,8 +371,8 @@ A confirm box is often used to ask permission from a user to execute something.
Clicking the OK yields true value, whereas clicking the Cancel button yields false value. Clicking the OK yields true value, whereas clicking the Cancel button yields false value.
```js ```js
const agree = confirm('Are you sure you like to delete? ') const agree = confirm("Are you sure you like to delete? ");
console.log(agree) // result will be true or false based on what you click on the dialog box console.log(agree); // result will be true or false based on what you click on the dialog box
``` ```
These are not all the window methods we will have a separate section to go deep into window methods. These are not all the window methods we will have a separate section to go deep into window methods.
@ -382,7 +380,7 @@ These are not all the window methods we will have a separate section to go deep
## Date Object ## Date Object
Time is an important thing. We like to know the time a certain activity or event. In JavaScript current time and date is created using JavaScript Date Object. The object we create using Date object provides many methods to work with date and time.The methods we use to get date and time information from a date object values are started with a word _get_ because it provide the information. Time is an important thing. We like to know the time a certain activity or event. In JavaScript current time and date is created using JavaScript Date Object. The object we create using Date object provides many methods to work with date and time.The methods we use to get date and time information from a date object values are started with a word _get_ because it provide the information.
_getFullYear(), getMonth(), getDate(), getDay(), getHours(), getMinutes, getSeconds(), getMilliseconds(), getTime(), getDay()_ _getFullYear(), getMonth(), getDate(), getDay(), getHours(), getMinutes, getSeconds(), getMilliseconds(), getTime()_
![Date time Object](../images/date_time_object.png) ![Date time Object](../images/date_time_object.png)
@ -391,8 +389,8 @@ _getFullYear(), getMonth(), getDate(), getDay(), getHours(), getMinutes, getSeco
Once we create time object. The time object will provide information about time. Let us create a time object Once we create time object. The time object will provide information about time. Let us create a time object
```js ```js
const now = new Date() const now = new Date();
console.log(now) // Sat Jan 04 2020 00:56:41 GMT+0200 (Eastern European Standard Time) console.log(now); // Sat Jan 04 2020 00:56:41 GMT+0200 (Eastern European Standard Time)
``` ```
We have created a time object and we can access any date time information from the object using the get methods we have mentioned on the table. We have created a time object and we can access any date time information from the object using the get methods we have mentioned on the table.
@ -402,8 +400,8 @@ We have created a time object and we can access any date time information from t
Let's extract or get the full year from a time object. Let's extract or get the full year from a time object.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getFullYear()) // 2020 console.log(now.getFullYear()); // 2020
``` ```
### Getting month ### Getting month
@ -411,8 +409,8 @@ console.log(now.getFullYear()) // 2020
Let's extract or get the month from a time object. Let's extract or get the month from a time object.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getMonth()) // 0, because the month is January, month(0-11) console.log(now.getMonth()); // 0, because the month is January, month(0-11)
``` ```
### Getting date ### Getting date
@ -420,8 +418,8 @@ console.log(now.getMonth()) // 0, because the month is January, month(0-11)
Let's extract or get the date of the month from a time object. Let's extract or get the date of the month from a time object.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getDate()) // 4, because the day of the month is 4th, day(1-31) console.log(now.getDate()); // 4, because the day of the month is 4th, day(1-31)
``` ```
### Getting day ### Getting day
@ -429,8 +427,8 @@ console.log(now.getDate()) // 4, because the day of the month is 4th, day(1-31)
Let's extract or get the day of the week from a time object. Let's extract or get the day of the week from a time object.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getDay()) // 6, because the day is Saturday which is the 7th day console.log(now.getDay()); // 6, because the day is Saturday which is the 7th day
// Sunday is 0, Monday is 1 and Saturday is 6 // Sunday is 0, Monday is 1 and Saturday is 6
// Getting the weekday as a number (0-6) // Getting the weekday as a number (0-6)
``` ```
@ -440,8 +438,8 @@ console.log(now.getDay()) // 6, because the day is Saturday which is the 7th day
Let's extract or get the hours from a time object. Let's extract or get the hours from a time object.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getHours()) // 0, because the time is 00:56:41 console.log(now.getHours()); // 0, because the time is 00:56:41
``` ```
### Getting minutes ### Getting minutes
@ -449,8 +447,8 @@ console.log(now.getHours()) // 0, because the time is 00:56:41
Let's extract or get the minutes from a time object. Let's extract or get the minutes from a time object.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getMinutes()) // 56, because the time is 00:56:41 console.log(now.getMinutes()); // 56, because the time is 00:56:41
``` ```
### Getting seconds ### Getting seconds
@ -458,8 +456,8 @@ console.log(now.getMinutes()) // 56, because the time is 00:56:41
Let's extract or get the seconds from a time object. Let's extract or get the seconds from a time object.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getSeconds()) // 41, because the time is 00:56:41 console.log(now.getSeconds()); // 41, because the time is 00:56:41
``` ```
### Getting time ### Getting time
@ -469,35 +467,35 @@ This method give time in milliseconds starting from January 1, 1970. It is also
1. Using _getTime()_ 1. Using _getTime()_
```js ```js
const now = new Date() // const now = new Date(); //
console.log(now.getTime()) // 1578092201341, this is the number of seconds passed from January 1, 1970 to January 4, 2020 00:56:41 console.log(now.getTime()); // 1578092201341, this is the number of seconds passed from January 1, 1970 to January 4, 2020 00:56:41
``` ```
1. Using _Date.now()_ 1. Using _Date.now()_
```js ```js
const allSeconds = Date.now() // const allSeconds = Date.now(); //
console.log(allSeconds) // 1578092201341, this is the number of seconds passed from January 1, 1970 to January 4, 2020 00:56:41 console.log(allSeconds); // 1578092201341, this is the number of seconds passed from January 1, 1970 to January 4, 2020 00:56:41
const timeInSeconds = new Date().getTime() const timeInSeconds = new Date().getTime();
console.log(allSeconds == timeInSeconds) // true console.log(allSeconds == timeInSeconds); // true
``` ```
Let us format these values to a human readable time format. Let us format these values to a human readable time format.
**Example:** **Example:**
```js ```js
const now = new Date() const now = new Date();
const year = now.getFullYear() // return year const year = now.getFullYear(); // return year
const month = now.getMonth() + 1 // return month(0 - 11) const month = now.getMonth() + 1; // return month(0 - 11)
const date = now.getDate() // return date (1 - 31) const date = now.getDate(); // return date (1 - 31)
const hours = now.getHours() // return number (0 - 23) const hours = now.getHours(); // return number (0 - 23)
const minutes = now.getMinutes() // return number (0 -59) const minutes = now.getMinutes(); // return number (0 -59)
console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // 4/1/2020 0:56 console.log(`${date}/${month}/${year} ${hours}:${minutes}`); // 4/1/2020 0:56
``` ```
🌕 You have boundless energy. You have just completed day 3 challenges and you are three steps a head in to your way to greatness. Now do some exercises for your brain and for your muscle. 🌕 You have boundless energy. You have just completed day 3 challenges and you are three steps a head in to your way to greatness. Now do some exercises for your brain and for your muscle.
## 💻 Day 3: Exercises ## 💻 Day 3: Exercises
@ -507,10 +505,12 @@ console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // 4/1/2020 0:56
2. Check if type of '10' is equal to 10 2. Check if type of '10' is equal to 10
3. Check if parseInt('9.8') is equal to 10 3. Check if parseInt('9.8') is equal to 10
4. Boolean value is either true or false. 4. Boolean value is either true or false.
1. Write three JavaScript statement which provide truthy value. 1. Write three JavaScript statement which provide truthy value.
2. Write three JavaScript statement which provide falsy value. 2. Write three JavaScript statement which provide falsy value.
5. Figure out the result of the following comparison expression first without using console.log(). After you decide the result confirm it using console.log() 5. Figure out the result of the following comparison expression first without using console.log(). After you decide the result confirm it using console.log()
1. 4 > 3 1. 4 > 3
2. 4 >= 3 2. 4 >= 3
3. 4 < 3 3. 4 < 3
@ -525,6 +525,7 @@ console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // 4/1/2020 0:56
12. Find the length of python and jargon and make a falsy comparison statement. 12. Find the length of python and jargon and make a falsy comparison statement.
6. Figure out the result of the following expressions first without using console.log(). After you decide the result confirm it by using console.log() 6. Figure out the result of the following expressions first without using console.log(). After you decide the result confirm it by using console.log()
1. 4 > 3 && 10 < 12 1. 4 > 3 && 10 < 12
2. 4 > 3 && 10 > 12 2. 4 > 3 && 10 > 12
3. 4 > 3 || 10 < 12 3. 4 > 3 || 10 < 12
@ -573,29 +574,29 @@ console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // 4/1/2020 0:56
1. Calculate the value of y (y = x<sup>2</sup> + 6x + 9). Try to use different x values and figure out at what x value y is 0. 1. Calculate the value of y (y = x<sup>2</sup> + 6x + 9). Try to use different x values and figure out at what x value y is 0.
1. Writ a script that prompt a user to enter hours and rate per hour. Calculate pay of the person? 1. Writ a script that prompt a user to enter hours and rate per hour. Calculate pay of the person?
```sh ```sh
Enter hours: 40 Enter hours: 40
Enter rate per hour: 28 Enter rate per hour: 28
Your weekly earning is 1120 Your weekly earning is 1120
``` ```
1. If the length of your name is greater than 7 say, your name is long else say your name is short. 1. If the length of your name is greater than 7 say, your name is long else say your name is short.
1. Compare your first name length and your family name length and you should get this output. 1. Compare your first name length and your family name length and you should get this output.
```js ```js
let firstName = 'Asabeneh' let firstName = "Asabeneh";
let lastName = 'Yetayeh' let lastName = "Yetayeh";
``` ```
```sh ```sh
Your first name, Asabeneh is longer than your family name, Yetayeh Your first name, Asabeneh is longer than your family name, Yetayeh
``` ```
1. Declare two variables _myAge_ and _yourAge_ and assign them initial values and myAge and yourAge. 1. Declare two variables _myAge_ and _yourAge_ and assign them initial values and myAge and yourAge.
```js ```js
let myAge = 250 let myAge = 250;
let yourAge = 25 let yourAge = 25;
``` ```
```sh ```sh
@ -604,14 +605,14 @@ console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // 4/1/2020 0:56
1. Using prompt get the year the user was born and if the user is 18 or above allow the user to drive if not tell the user to wait a certain amount of years. 1. Using prompt get the year the user was born and if the user is 18 or above allow the user to drive if not tell the user to wait a certain amount of years.
```sh ```sh
Enter birth year: 1995 Enter birth year: 1995
You are 25. You are old enough to drive You are 25. You are old enough to drive
Enter birth year: 2005 Enter birth year: 2005
You are 15. You will be allowed to drive after 3 years. You are 15. You will be allowed to drive after 3 years.
``` ```
1. Write a script that prompt the user to enter number of years. Calculate the number of seconds a person can live. Assume some one lives just hundred years 1. Write a script that prompt the user to enter number of years. Calculate the number of seconds a person can live. Assume some one lives just hundred years

@ -1,5 +1,5 @@
<div align="center"> <div align="center">
<h1> 30 Days Of JavaScript: Booleans (Boole Değerler), Operators (Operatörler), Date (Tarih Objesi)</h1> <h1> 30 Days Of JavaScript: Booleans (Boole Değerler), Operators (Operatörler), Date (Tarih Nesnesi)</h1>
<a class="header-badge" target="_blank" href="https://www.linkedin.com/in/asabeneh/"> <a class="header-badge" target="_blank" href="https://www.linkedin.com/in/asabeneh/">
<img src="https://img.shields.io/badge/style--5eba00.svg?label=LinkedIn&logo=linkedin&style=social"> <img src="https://img.shields.io/badge/style--5eba00.svg?label=LinkedIn&logo=linkedin&style=social">
</a> </a>
@ -7,10 +7,11 @@
<img alt="Twitter Follow" src="https://img.shields.io/twitter/follow/asabeneh?style=social"> <img alt="Twitter Follow" src="https://img.shields.io/twitter/follow/asabeneh?style=social">
</a> </a>
<sub>Author: <sub>Author:
<a href="https://www.linkedin.com/in/asabeneh/" target="_blank">Asabeneh Yetayeh</a><br> <a href="https://www.linkedin.com/in/asabeneh/" target="_blank">Asabeneh Yetayeh</a><br>
<small> January, 2020</small> <small> January, 2020</small>
</sub> </sub>
</div> </div>
[<< Gün 2](../02_Day_Data_types/02_day_data_types.md) | [Gün 4 >>](../04_Day_Conditionals/04_day_conditionals.md) [<< Gün 2](../02_Day_Data_types/02_day_data_types.md) | [Gün 4 >>](../04_Day_Conditionals/04_day_conditionals.md)
@ -18,38 +19,38 @@
![30 Günde JavaScript](../../images/banners/day_1_3.png) ![30 Günde JavaScript](../../images/banners/day_1_3.png)
- [📔 Gün 3](#-gün-3) - [📔 Gün 3](#-gün-3)
- [Boolean Değerleri](#boolean-degerleri) - [Boolean Değerleri](#boolean-degerleri)
- [Doğru Değerleri](#doğru-değerleri) - [Doğru Değerleri](#doğru-değerleri)
- [Yanlış Değerleri](#yanlış-değerleri) - [Yanlış Değerleri](#yanlış-değerleri)
- [Tanımsız](#tanımsız) - [Tanımsız](#tanımsız)
- [Boş](#boş) - [Boş](#boş)
- [Operatörler](#operatörler) - [Operatörler](#operatörler)
- [Atama Operatörleri](#atama-operatörleri) - [Atama Operatörleri](#atama-operatörleri)
- [Aritmetik Operatörleri](#aritmetik-operatörleri) - [Aritmetik Operatörleri](#aritmetik-operatörleri)
- [Karşılaştırma Operatörleri](#karşılaştırma-operatörleri) - [Karşılaştırma Operatörleri](#karşılaştırma-operatörleri)
- [Mantıksal Operatörler](#mantıksal-operatörler) - [Mantıksal Operatörler](#mantıksal-operatörler)
- [Arttırma Operatörü](#arttırma-operatörü) - [Arttırma Operatörü](#arttırma-operatörü)
- [Azaltma Operatörü](#azaltma-operatörü) - [Azaltma Operatörü](#azaltma-operatörü)
- [Koşul Operatörü](#koşul-operatörü) - [Koşul Operatörü](#koşul-operatörü)
- [Operatör Önceliği](#operatör-önceliği) - [Operatör Önceliği](#operatör-önceliği)
- [Window Metotları](#window-metotları) - [Window Metotları](#window-metotları)
- [Window alert() metot](#window-alert-metot) - [Window alert() metot](#window-alert-metot)
- [Window prompt() metot](#window-prompt-metot) - [Window prompt() metot](#window-prompt-metot)
- [Window confirm() metot](#window-confirm-metot) - [Window confirm() metot](#window-confirm-metot)
- [Date Objesi](#date-objesi) - [Date Nesnesi](#date-nesnesi)
- [Bir Zaman Objesi Oluşturma](#bir-zaman-objesi-oluşturma) - [Bir Zaman Nesnesi Oluşturma](#bir-zaman-nesnesi-oluşturma)
- [Tam Yılı Almak](#tam-yılı-almak) - [Tam Yılı Almak](#tam-yılı-almak)
- [Ayı Almak](#ayı-almak) - [Ayı Almak](#ayı-almak)
- [Tarihi Almak](#tarihi-almak) - [Tarihi Almak](#tarihi-almak)
- [Günü Almak](#günü-almak) - [Günü Almak](#günü-almak)
- [Saati Almak](#saati-almak) - [Saati Almak](#saati-almak)
- [Dakikayı Almak](#dakikayı-almak) - [Dakikayı Almak](#dakikayı-almak)
- [Saniyeyi Almak](#saniyeyi-almak) - [Saniyeyi Almak](#saniyeyi-almak)
- [Zamanı Almak](#zamanı-almak) - [Zamanı Almak](#zamanı-almak)
- [💻 Gün 3: Egzersizleri](#-gün-3-egzersizleri) - [💻 Gün 3: Egzersizleri](#-gün-3-egzersizleri)
- [Egzersiz: Seviye 1](#egzersiz-seviye-1) - [Egzersiz: Seviye 1](#egzersiz-seviye-1)
- [Egzersiz: Seviye 2](#egzersiz-seviye-2) - [Egzersiz: Seviye 2](#egzersiz-seviye-2)
- [Egzersiz: Seviye 3](#egzersiz-seviye-3) - [Egzersiz: Seviye 3](#egzersiz-seviye-3)
# 📔 Gün 3 # 📔 Gün 3
@ -57,15 +58,15 @@
Boolean ver türü iki değerden birini temsil eder :_true_ yada _false_. Boolean değeri doğru veya yanlıştır. Karşılaştırma operatörlerini kullandığınızda sonuc netleşecektir. Herhangi bir karşılaştırma sonucu doğru veya yanlış olan bir boolean değeri döndürür. Boolean ver türü iki değerden birini temsil eder :_true_ yada _false_. Boolean değeri doğru veya yanlıştır. Karşılaştırma operatörlerini kullandığınızda sonuc netleşecektir. Herhangi bir karşılaştırma sonucu doğru veya yanlış olan bir boolean değeri döndürür.
**Örnek: Boolean Deperleri** **Örnek: Boolean Değerleri**
```js ```js
let isLightOn = true // ışık açık doğru let isLightOn = true; // ışık açık doğru
let isRaining = false // yağıyor yanlış let isRaining = false; // yağıyor yanlış
let isHungry = false // aç yanlış let isHungry = false; // aç yanlış
let isMarried = true // evli doğru let isMarried = true; // evli doğru
let truValue = 4 > 3 // true -- doğru let truValue = 4 > 3; // true -- doğru
let falseValue = 4 < 3 // false -- yanlış let falseValue = 4 < 3; // false -- yanlış
``` ```
Boolean değerlerinin doğru yada yanlış olduğunu kabul etmiştik. Boolean değerlerinin doğru yada yanlış olduğunu kabul etmiştik.
@ -74,7 +75,7 @@ Boolean değerlerinin doğru yada yanlış olduğunu kabul etmiştik.
- Sıfır hariç tüm sayılar (pozitif ve negatif) doğrudur - Sıfır hariç tüm sayılar (pozitif ve negatif) doğrudur
- Boş bir dize ('') dışında tüm dizeler doğrudur - Boş bir dize ('') dışında tüm dizeler doğrudur
- Boole değeri doğru - Boolean değeri doğru
### Yanlış Değerleri (false) ### Yanlış Değerleri (false)
@ -92,17 +93,16 @@ Bu doğru ve yanlış değerleri hatırlamakta fayda var. Daha sonraki bölümde
Bir değişken bildirirsek ve bir değer atamazsak, değer tanımsız olacaktır. Buna ek olarak, eğer bir fonksiyon değer döndürmüyorsa tanımsız olacaktır. Bir değişken bildirirsek ve bir değer atamazsak, değer tanımsız olacaktır. Buna ek olarak, eğer bir fonksiyon değer döndürmüyorsa tanımsız olacaktır.
```js ```js
let firstName let firstName;
console.log(firstName) //tanımlanmamış, çünkü henüz bir değer atanmamış. console.log(firstName); //tanımlanmamış, çünkü henüz bir değer atanmamış.
``` ```
## Boş (Null) ## Boş (Null)
```js ```js
let empty = null let empty = null;
console.log(empty) // -> null(boş) , değer yok anlamına gelir console.log(empty); // -> null(boş) , değer yok anlamına gelir
``` ```
## Operatörler ## Operatörler
@ -112,8 +112,8 @@ console.log(empty) // -> null(boş) , değer yok anlamına gelir
JavaScript'te eşittir işareti bir atama operatörüdür. Değişken atamak için kullanılır. JavaScript'te eşittir işareti bir atama operatörüdür. Değişken atamak için kullanılır.
```js ```js
let firstName = 'Asabeneh' let firstName = "Asabeneh";
let country = 'Finland' let country = "Finland";
``` ```
Atama Operatörleri Atama Operatörleri
@ -126,44 +126,41 @@ Aritmetik operatörler matematiksel operatörlerdir.
- Toplama(+): a + b - Toplama(+): a + b
- Çıkarma(-): a - b - Çıkarma(-): a - b
- Çarpma(*): a * b - Çarpma(_): a _ b
- Bölme(/): a / b - Bölme(/): a / b
- Kalan(Bölmedeki kalan)(%): a % b - Kalan (Bölmedeki kalan) (%): a % b
- (Örneğe Bak) Üstel Sayı (**): a ** b - (Örneğe Bak) Üstel Sayı (**): a ** b
```js ```js
let numOne = 4 let numOne = 4;
let numTwo = 3 let numTwo = 3;
let sum = numOne + numTwo // toplama let sum = numOne + numTwo; // toplama
let diff = numOne - numTwo // çıkarma let diff = numOne - numTwo; // çıkarma
let mult = numOne * numTwo // çarpma let mult = numOne * numTwo; // çarpma
let div = numOne / numTwo // bölme let div = numOne / numTwo; // bölme
let remainder = numOne % numTwo // kalanı bulma (bölmedeki kalan oluyor bu Biraz matematik :D ) let remainder = numOne % numTwo; // kalanı bulma (bölmedeki kalan oluyor bu Biraz matematik :D )
let powerOf = numOne ** numTwo // buda üstel sayı anlamına geliyor Örnek: 4 Üssü 3 Kaçtır? Biraz matematik 2 :D let powerOf = numOne ** numTwo; // bu da üstel sayı anlamına geliyor Örnek: 4 Üssü 3 Kaçtır? Biraz matematik 2 :D
console.log(sum, diff, mult, div, remainder, powerOf) // 7,1,12,1.33,1, 64 ---- Sonuçları console.log'a tek tek yazıp deneyin
console.log(sum, diff, mult, div, remainder, powerOf); // 7,1,12,1.33,1, 64 ---- Sonuçları console.log'a tek tek yazıp deneyin
``` ```
```js ```js
const PI = 3.14 const PI = 3.14;
let radius = 100 // metre cinsinden uzunluk let radius = 100; // metre cinsinden, uzunluk
// Bir dairenin alanını hesaplayalım // Bir dairenin alanını hesaplayalım
const areaOfCircle = PI * radius * radius const areaOfCircle = PI * radius * radius;
console.log(areaOfCircle) // 314 m console.log(areaOfCircle); // 314 m
const gravity = 9.81; // m/s2 cinsinden ( metre saniye cinsi )
const gravity = 9.81 // m/s2 cinsinden ( metre saniye cinsi ) let mass = 72; // kilogram cinsinden
let mass = 72 // kilogram cinsinden
// Bir cismin ağırlığını hesaplayalım // Bir cismin ağırlığını hesaplayalım
const weight = mass * gravity const weight = mass * gravity;
console.log(weight) // 706.32 N(Newton) console.log(weight); // 706.32 N(Newton)
const boilingPoint = 100 // oC cinsinden sıcaklık, suyun kaynama noktası
const bodyTemp = 37 // oC cinsinden vücut ısısı
const boilingPoint = 100; // oC cinsinden sıcaklık, suyun kaynama noktası
const bodyTemp = 37; // oC cinsinden vücut ısısı
// Dize enterpolasyonu kullanarak dizeyi sayılarla birleştirme // Dize enterpolasyonu kullanarak dizeyi sayılarla birleştirme
/* /*
@ -173,7 +170,7 @@ const bodyTemp = 37 // oC cinsinden vücut ısısı
*/ */
console.log( console.log(
`The boiling point of water is ${boilingPoint} oC.\nHuman body temperature is ${bodyTemp} oC.\nThe gravity of earth is ${gravity} m / s2.` `The boiling point of water is ${boilingPoint} oC.\nHuman body temperature is ${bodyTemp} oC.\nThe gravity of earth is ${gravity} m / s2.`
) );
``` ```
### Karşılaştırma Operatörleri ### Karşılaştırma Operatörleri
@ -184,38 +181,38 @@ Programlamada değerleri karşılaştırırız, iki değeri karşılaştırmak i
**Örnek: Karşılaştırma Operatörleri** **Örnek: Karşılaştırma Operatörleri**
```js ```js
console.log(3 > 2) // true, çünkü 3 2 den büyüktür console.log(3 > 2); // true, çünkü 3 2 den büyüktür
console.log(3 >= 2) // true, çünkü 3 2 den büyüktür console.log(3 >= 2); // true, çünkü 3 2 den büyüktür
console.log(3 < 2) // false, çünkü 3 2 den büyüktür console.log(3 < 2); // false, çünkü 3 2 den büyüktür
console.log(2 < 3) // true, çünkü 2 3 den küçüktür console.log(2 < 3); // true, çünkü 2 3 den küçüktür
console.log(2 <= 3) // true, çünkü 2 3 den küçüktür console.log(2 <= 3); // true, çünkü 2 3 den küçüktür
console.log(3 == 2) // false, çünkü 3 2 ye eşit değildir console.log(3 == 2); // false, çünkü 3 2 ye eşit değildir
console.log(3 != 2) // true, çünkü 3 2 ye eşit değildir console.log(3 != 2); // true, çünkü 3 2 ye eşit değildir
console.log(3 == '3') // true, sadece değeri karşılaştırıyor console.log(3 == "3"); // true, sadece değeri karşılaştırıyor
console.log(3 === '3') // false, hem değeri hemde veri türünü karşılaştırıyor o yüzden yanlış. Birisi int değeri birisi string değerinden ( Bu denklik operatörü ) console.log(3 === "3"); // false, hem değeri hem de veri türünü karşılaştırıyor o yüzden yanlış. Birisi int değeri, diğeri ise string değeridir (Bu, denklik operatörü )
console.log(3 !== '3') // true, hem değeri hemde veri türünü karşılaştırıyor o yüzden doğru. (Bu denk değil operatörü) console.log(3 !== "3"); // true, hem değeri hem de veri türünü karşılaştırıyor o yüzden doğru. (Bu, denk değil operatörü)
console.log(3 != 3) // false, değeri karşılaştırıyor console.log(3 != 3); // false, değeri karşılaştırıyor
console.log(3 !== 3) // false, hem değeri hem de veri türünü karşılaştırıyor console.log(3 !== 3); // false, hem değeri hem de veri türünü karşılaştırıyor
console.log(0 == false) // true, eşdeğer console.log(0 == false); // true, eşdeğer
console.log(0 === false) // false, tam olarak aynı değil console.log(0 === false); // false, tam olarak aynı değil
console.log(0 == '') // true, eşdeğer console.log(0 == ""); // true, eşdeğer
console.log(0 == ' ') // true, eşdeğer console.log(0 == " "); // true, eşdeğer
console.log(0 === '') // false, tam olarak aynı değil console.log(0 === ""); // false, tam olarak aynı değil
console.log(1 == true) // true, eşdeğer console.log(1 == true); // true, eşdeğer
console.log(1 === true) // false, tam olarak aynı değil console.log(1 === true); // false, tam olarak aynı değil
console.log(undefined == null) // true console.log(undefined == null); // true
console.log(undefined === null) // false console.log(undefined === null); // false
console.log(NaN == NaN) // false, eşit değil console.log(NaN == NaN); // false, eşit değil
console.log(NaN === NaN) // false console.log(NaN === NaN); // false
console.log(typeof NaN) // number console.log(typeof NaN); // number
console.log('mango'.length == 'avocado'.length) // false console.log("mango".length == "avocado".length); // false
console.log('mango'.length != 'avocado'.length) // true console.log("mango".length != "avocado".length); // true
console.log('mango'.length < 'avocado'.length) // true console.log("mango".length < "avocado".length); // true
console.log('milk'.length == 'meat'.length) // true console.log("milk".length == "meat".length); // true
console.log('milk'.length != 'meat'.length) // false console.log("milk".length != "meat".length); // false
console.log('tomato'.length == 'potato'.length) // true console.log("tomato".length == "potato".length); // true
console.log('python'.length > 'dragon'.length) // false console.log("python".length > "dragon".length); // false
``` ```
Yukarıdaki karşılaştırmaları biraz mantıkla anlamaya çalışın. Herhangi bir mantık olmadan hatırlamak zor olabilir. Yukarıdaki karşılaştırmaları biraz mantıkla anlamaya çalışın. Herhangi bir mantık olmadan hatırlamak zor olabilir.
@ -229,53 +226,52 @@ Aşağıdaki semboller ortak mantıksal operatörlerdir:
&&(ve işareti) , || (boru -veya-) ve !(olumsuzlama). &&(ve işareti) , || (boru -veya-) ve !(olumsuzlama).
&& operatörü, yalnızca iki işlenen doğruysa doğru olur. && operatörü, yalnızca iki işlenen doğruysa doğru olur.
|| operatör, işlenenlerden herhangi birinin doğru olması durumunda gerçekleşir. || operatör, işlenenlerden herhangi birinin doğru olması durumunda gerçekleşir.
! operatör true - false ve false - true değerini olumsuzlar. ! operatör true - false ve false - true değerini olumsuzlar. (true'yu false, false'u true yapar)
```js ```js
// && ve işareti operatörü örneği ( ampersand olarak anlandırılıyor) // && ve işareti operatörü örneği ( ampersand olarak adlandırılır)
const check = 4 > 3 && 10 > 5 // true && true -> true const check = 4 > 3 && 10 > 5; // true && true -> true
const check = 4 > 3 && 10 < 5 // true && false -> false const check = 4 > 3 && 10 < 5; // true && false -> false
const check = 4 < 3 && 10 < 5 // false && false -> false const check = 4 < 3 && 10 < 5; // false && false -> false
// || boru veya operatör, örnek // || boru veya operatörüdür, örnek
const check = 4 > 3 || 10 > 5 // true || true -> true const check = 4 > 3 || 10 > 5; // true || true -> true
const check = 4 > 3 || 10 < 5 // true || false -> true const check = 4 > 3 || 10 < 5; // true || false -> true
const check = 4 < 3 || 10 < 5 // false || false -> false const check = 4 < 3 || 10 < 5; // false || false -> false
//! olumsuzlama örnekleri //! olumsuzlama örnekleri
let check = 4 > 3 // true let check = 4 > 3; // true
let check = !(4 > 3) // false let check = !(4 > 3); // false
let isLightOn = true let isLightOn = true;
let isLightOff = !isLightOn // false let isLightOff = !isLightOn; // false
let isMarried = !false // true let isMarried = !false; // true
``` ```
### Arttırma Operatörü ### Arttırma Operatörü
JavaScript'te, bir değişkende saklanan bir değeri artırmak için artırma operatörünü kullanırız. Artış, artış öncesi veya sonrası olabilir. Her birini görelim: JavaScript'te, bir değişkende saklanan bir değeri artırmak için artırma operatörünü kullanırız. Artış, öncesi veya sonrası olabilir. Her birini görelim:
1. Öncesi Artış 1. Öncesi Artış
```js ```js
let count = 0 let count = 0;
console.log(++count) // 1 console.log(++count); // 1
console.log(count) // 1 console.log(count); // 1
``` ```
1. Sonrası Artış 1. Sonrası Artış
```js ```js
let count = 0 let count = 0;
console.log(count++) // 0 console.log(count++); // 0
console.log(count) // 1 console.log(count); // 1
``` ```
Artış sonrası zamanın çoğunu kullanırız. En azından artım sonrası operatörünü nasıl kullanacağınızı hatırlamalısınız. Artış sonrası zamanın çoğunu kullanırız. En azından artım sonrası operatörünü nasıl kullanacağınızı hatırlamalısınız.
### Azaltma Operatörü ### Azaltma Operatörü
JavaScript'te, bir değişkende saklanan bir değeri azaltmak için azaltma operatörünü kullanırız. Azaltma, eksiltme öncesi veya sonrası olabilir. Her birini görelim: JavaScript'te, bir değişkende saklanan bir değeri azaltmak için azaltma operatörünü kullanırız. Azaltma, eksiltme öncesi veya sonrası olabilir. Her birini görelim:
@ -283,34 +279,34 @@ JavaScript'te, bir değişkende saklanan bir değeri azaltmak için azaltma oper
1. Öncesi Azaltma 1. Öncesi Azaltma
```js ```js
let count = 0 let count = 0;
console.log(--count) // -1 console.log(--count); // -1
console.log(count) // -1 console.log(count); // -1
``` ```
2. Sonrası Azaltma 2. Sonrası Azaltma
```js ```js
let count = 0 let count = 0;
console.log(count--) // 0 console.log(count--); // 0
console.log(count) // -1 console.log(count); // -1
``` ```
### Koşul Operatörü (Ternary - Üçlü ) ### Koşul Operatörü (Ternary - Üçlü )
Üçlü operatör bir koşul yazmaya izin verir. Üçlü operatör bir koşul yazmaya izin verir.
Koşullar yazmanın başka bir yolu da üçlü operatörleri kullanmaktır. Aşağıdaki örneklere bakın: Koşullar yazmanın başka bir yolu da üçlü operatörü kullanmaktır. Aşağıdaki örneklere bakın:
```js ```js
let isRaining = true let isRaining = true;
isRaining isRaining
? console.log('You need a rain coat.') ? console.log("You need a rain coat.")
: console.log('No need for a rain coat.') : console.log("No need for a rain coat.");
isRaining = false isRaining = false;
isRaining isRaining
? console.log('You need a rain coat.') ? console.log("You need a rain coat.")
: console.log('No need for a rain coat.') : console.log("No need for a rain coat.");
``` ```
```sh ```sh
@ -319,15 +315,15 @@ No need for a rain coat.
``` ```
```js ```js
let number = 5 let number = 5;
number > 0 number > 0
? console.log(`${number} is a positive number`) ? console.log(`${number} is a positive number`)
: console.log(`${number} is a negative number`) : console.log(`${number} is a negative number`);
number = -5 number = -5;
number > 0 number > 0
? console.log(`${number} is a positive number`) ? console.log(`${number} is a positive number`)
: console.log(`${number} is a negative number`) : console.log(`${number} is a negative number`);
``` ```
```sh ```sh
@ -346,11 +342,11 @@ Bu [bağlantıdan](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Refer
En başta gördüğünüz gibi alert() metodu, belirtilen bir mesaj ve bir Tamam butonu ile bir uyarı kutusu görüntüler. Yerleşik bir yöntemdir ve argüman alır. En başta gördüğünüz gibi alert() metodu, belirtilen bir mesaj ve bir Tamam butonu ile bir uyarı kutusu görüntüler. Yerleşik bir yöntemdir ve argüman alır.
```js ```js
alert(message) alert(message);
``` ```
```js ```js
alert('Welcome to 30DaysOfJavaScript') alert("Welcome to 30DaysOfJavaScript");
``` ```
Yıkıcı ve sinir bozucu olduğu için çok fazla uyarı kullanmayın, sadece test etmek için kullanın. Yıkıcı ve sinir bozucu olduğu için çok fazla uyarı kullanmayın, sadece test etmek için kullanın.
@ -360,12 +356,12 @@ Yıkıcı ve sinir bozucu olduğu için çok fazla uyarı kullanmayın, sadece t
Pencere yöntemleri, tarayıcınızda giriş değerlerini almak için bir giriş içeren bir bilgi istemi kutusu görüntüler ve giriş verileri bir değişkende saklanabilir. prompt() yöntemi iki argüman alır. İkinci argüman isteğe bağlıdır. Pencere yöntemleri, tarayıcınızda giriş değerlerini almak için bir giriş içeren bir bilgi istemi kutusu görüntüler ve giriş verileri bir değişkende saklanabilir. prompt() yöntemi iki argüman alır. İkinci argüman isteğe bağlıdır.
```js ```js
prompt('required text', 'optional text') prompt("required text", "optional text");
``` ```
```js ```js
let number = prompt('Enter number', 'number goes here') let number = prompt("Enter number", "number goes here");
console.log(number) console.log(number);
``` ```
### Window confirm() metot ### Window confirm() metot
@ -375,95 +371,93 @@ Bir onay kutusu genellikle bir kullanıcıdan bir şeyi yürütmek için izin is
Tamam'a tıklamak doğru değeri verir, İptal düğmesine tıklamak yanlış değeri verir. Tamam'a tıklamak doğru değeri verir, İptal düğmesine tıklamak yanlış değeri verir.
```js ```js
const agree = confirm('Are you sure you like to delete? ') const agree = confirm("Are you sure you like to delete? ");
console.log(agree) // result will be true or false based on what you click on the dialog box console.log(agree); // result will be true or false based on what you click on the dialog box
``` ```
Bunların hepsi window yöntemleri değil, window yöntemlerine derinlemesine girmek için ayrı bir bölümümüz olacak. Bunların hepsi window yöntemleri değil, window yöntemlerine derinlemesine girmek için ayrı bir bölümümüz olacak.
## Date Objesi ## Date Nesnesi
Zaman önemli bir şeydir. Belirli bir faaliyetin veya olayın zamanını bilmek isteriz. JavaScript'te geçerli saat ve tarih, JavaScript Date Objesi kullanılarak oluşturulur. Date objesini kullanarak oluşturduğumuz nesne, tarih ve saat ile çalışmak için birçok yöntem sunar. Bir tarih nesnesi değerlerinden tarih ve saat bilgisi almak için kullandığımız yöntemler, bilgiyi sağladığı için _get_ kelimesi ile başlamaktadır.
_getFullYear(), getMonth(), getDate(), getDay(), getHours(), getMinutes, getSeconds(), getMilliseconds(), getTime(), getDay()_
Zaman önemli bir şeydir. Belirli bir faaliyetin veya olayın zamanını bilmek isteriz. JavaScript'te geçerli saat ve tarih, JavaScript Date Nesnesi kullanılarak oluşturulur. Date nesnesini kullanarak oluşturduğumuz nesne, tarih ve saat ile çalışmak için birçok yöntem sunar. Bir tarih nesnesi değerlerinden tarih ve saat bilgisi almak için kullandığımız yöntemler, bilgiyi sağladığı için _get_ kelimesi ile başlamaktadır.
_getFullYear(), getMonth(), getDate(), getDay(), getHours(), getMinutes, getSeconds(), getMilliseconds(), getTime()_
![Date time objesi](../../images/date_time_object.png) ![Date time nesnesi](../../images/date_time_object.png)
### Bir Zaman Objesi Oluşturma ### Bir Zaman Nesnesi Oluşturma
Bir kez zaman objesi oluşturduğumuzda zaman objesi, zaman hakkında bilgi sağlayacaktır. Bir zaman objesi oluşturalım. Bir kez zaman nesnesi oluşturduğumuzda zaman nesnesi, zaman hakkında bilgi sağlayacaktır. Bir zaman nesnesi oluşturalım.
```js ```js
const now = new Date() const now = new Date();
console.log(now) // Sat Jan 04 2020 00:56:41 GMT+0200 (Eastern European Standard Time) console.log(now); // Sat Jan 04 2020 00:56:41 GMT+0200 (Eastern European Standard Time)
``` ```
Bir time objesi oluşturduk ve tablo üzerinde bahsettiğimiz get yöntemlerini kullanarak objeden herhangi bir tarih saat bilgisine ulaşabiliyoruz. Bir time nesnesi oluşturduk ve tablo üzerinde bahsettiğimiz get yöntemlerini kullanarak nesneden herhangi bir tarih saat bilgisine ulaşabiliyoruz.
### Tam Yılı Almak ### Tam Yılı Almak
Bir zaman objesinden tam yılı çıkaralım veya alalım. Bir zaman nesnesinden tam yılı çıkaralım veya alalım.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getFullYear()) // 2020 console.log(now.getFullYear()); // 2020
``` ```
### Ayı Almak ### Ayı Almak
Bir zaman objesinden ayı çıkaralım veya alalım. Bir zaman nesnesinden ayı çıkaralım veya alalım.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getMonth()) // Bunu yazdığınızda muhtemelen bulunduğunuz aydan bir önceki ayın sayısını alıcaktır çünkü aylar 0-11 arasında oluşuyor. Ocak 1 değil 0. ay oluyor aralıkta 11. ay oluyor. console.log(now.getMonth()); // Bunu yazdığınızda muhtemelen bulunduğunuz aydan bir önceki ayın sayısını alıcaktır çünkü aylar 0-11 arasında oluşuyor. Ocak 1 değil, 0. ay oluyor; Aralık 11. ay oluyor.
``` ```
### Tarihi Almak ### Tarihi Almak
Bir zaman objesinden ayın tarihini çıkaralım veya alalım. Bir zaman nesnesinden ayın tarihini çıkaralım veya alalım.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getDate()) // yukardaki örnekte bulunan açıklamaya ek olarak geçen ayın gün sayısını verecektir. console.log(now.getDate()); // yukarıdaki örnekte bulunan açıklamaya ek olarak geçen ayın gün sayısını verecektir.
``` ```
### Günü Almak ### Günü Almak
Bir zaman objesinden haftanın gününü çıkaralım veya alalım. Bir zaman nesnesinden haftanın gününü çıkaralım veya alalım.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getDay()) // 6, because the day is Saturday which is the 7th day console.log(now.getDay()); // 6, çünkü gün Cumartesi, bu da 7. gündür.
// Sunday is 0, Monday is 1 and Saturday is 6 // Pazar 0, Pazartesi 1 ve Cumartesi 6'dır.
// Getting the weekday as a number (0-6) // Haftanın gününü bir sayı olarak almak (0-6).
``` ```
### Saati Almak ### Saati Almak
Bir zaman objesinden saatleri çıkaralım veya alalım. Bir zaman nesnesinden saatleri çıkaralım veya alalım.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getHours()) console.log(now.getHours());
``` ```
### Dakikayı Almak ### Dakikayı Almak
Bir zaman objesinden dakikaları çıkaralım veya alalım. Bir zaman nesnesinden dakikaları çıkaralım veya alalım.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getMinutes()) console.log(now.getMinutes());
``` ```
### Saniyeyi Almak ### Saniyeyi Almak
Bir zaman objesinden saniyeleri çıkaralım veya alalım. Bir zaman nesnesinden saniyeleri çıkaralım veya alalım.
```js ```js
const now = new Date() const now = new Date();
console.log(now.getSeconds()) console.log(now.getSeconds());
``` ```
### Zamanı Almak ### Zamanı Almak
@ -473,18 +467,18 @@ Bu metot 1 Ocak 1970'den itibaren milisaniye cinsinden süre verir. Unix zamanı
1. _getTime()_ Kullanımı 1. _getTime()_ Kullanımı
```js ```js
const now = new Date() // const now = new Date(); //
console.log(now.getTime()) // çıktı farklı olacaktır , 1 Ocak 1970 den kullandığınız zaman arasındaki süreyi milisaniye cinsinden verecektir. console.log(now.getTime()); // çıktı farklı olacaktır , 1 Ocak 1970 den kullandığınız zaman arasındaki süreyi milisaniye cinsinden verecektir.
``` ```
1. _Date.now()_ Kullanımı 1. _Date.now()_ Kullanımı
```js ```js
const allSeconds = Date.now() // const allSeconds = Date.now(); //
console.log(allSeconds) // çıktı farklı olacaktır , 1 Ocak 1970 den kullandığınız zaman arasındaki süreyi milisaniye cinsinden verecektir. console.log(allSeconds); // çıktı farklı olacaktır , 1 Ocak 1970 den kullandığınız zaman arasındaki süreyi milisaniye cinsinden verecektir.
const timeInSeconds = new Date().getTime() const timeInSeconds = new Date().getTime();
console.log(allSeconds == timeInSeconds) // true console.log(allSeconds == timeInSeconds); // true
``` ```
Bu değerleri insan tarafından okunabilir bir zaman biçimine biçimlendirelim. Bu değerleri insan tarafından okunabilir bir zaman biçimine biçimlendirelim.
@ -492,17 +486,17 @@ Bu değerleri insan tarafından okunabilir bir zaman biçimine biçimlendirelim.
**Örnek:** **Örnek:**
```js ```js
const now = new Date() const now = new Date();
const year = now.getFullYear() // yılı döndürür const year = now.getFullYear(); // yılı döndürür
const month = now.getMonth() + 1 // ayı döndürür (0 - 11) olduğu için +1 ekliyor const month = now.getMonth() + 1; // ayı döndürür (0 - 11) olduğu için +1 ekliyor
const date = now.getDate() // günü döndürür (1 - 31) const date = now.getDate(); // günü döndürür (1 - 31)
const hours = now.getHours() // sayıyı döndürür (0 - 23) const hours = now.getHours(); // sayıyı döndürür (0 - 23)
const minutes = now.getMinutes() // sayıyı döndürür (0 -59) const minutes = now.getMinutes(); // sayıyı döndürür (0 -59)
console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // çıktı farklı olacaktır console.log(`${date}/${month}/${year} ${hours}:${minutes}`); // çıktı farklı olacaktır
``` ```
🌕 Sınırsız bir enerjiniz var. 3. gün zorluklarını yeni tamamladınız ve mükemmelliğe giden yolda üç adım öndesiniz. Şimdi beyniniz ve kasınız için bazı egzersizler yapın. 🌕 Sınırsız bir enerjiniz var. 3. gün zorluklarını yeni tamamladınız ve mükemmelliğe giden yolda üç adım öndesiniz. Şimdi beyniniz ve kasınız için bazı egzersizler yapın.
## 💻 Gün 3: Egzersizleri ## 💻 Gün 3: Egzersizleri
@ -512,10 +506,12 @@ console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // çıktı farklı
2. '10' türünün 10'a eşit olup olmadığını kontrol edin 2. '10' türünün 10'a eşit olup olmadığını kontrol edin
3. parseInt('9.8') 10'a eşit olup olmadığını kontrol edin 3. parseInt('9.8') 10'a eşit olup olmadığını kontrol edin
4. Boolean değeri, doğru veya yanlıştır. 4. Boolean değeri, doğru veya yanlıştır.
1. Doğruluk değeri sağlayan üç JavaScript ifadesi yazın. 1. Doğruluk değeri sağlayan üç JavaScript ifadesi yazın.
2. Yanlış değer sağlayan üç JavaScript ifadesi yazın. 2. Yanlış değer sağlayan üç JavaScript ifadesi yazın.
5. console.log() kullanmadan önce aşağıdaki karşılaştırma ifadesinin sonucunu bulun. Sonuca karar verdikten sonra console.log() kullanarak onaylayın. 5. console.log() kullanmadan önce aşağıdaki karşılaştırma ifadesinin sonucunu bulun. Sonuca karar verdikten sonra console.log() kullanarak onaylayın.
1. 4 > 3 1. 4 > 3
2. 4 >= 3 2. 4 >= 3
3. 4 < 3 3. 4 < 3
@ -530,6 +526,7 @@ console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // çıktı farklı
12. Python ve jargonun uzunluğunu bulun ve yanlış bir karşılaştırma ifadesi yapın. 12. Python ve jargonun uzunluğunu bulun ve yanlış bir karşılaştırma ifadesi yapın.
6. console.log() kullanmadan önce aşağıdaki ifadelerin sonucunu bulun. Sonuca karar verdikten sonra console.log() kullanarak onaylayın. 6. console.log() kullanmadan önce aşağıdaki ifadelerin sonucunu bulun. Sonuca karar verdikten sonra console.log() kullanarak onaylayın.
1. 4 > 3 && 10 < 12 1. 4 > 3 && 10 < 12
2. 4 > 3 && 10 > 12 2. 4 > 3 && 10 > 12
3. 4 > 3 || 10 < 12 3. 4 > 3 || 10 < 12
@ -578,29 +575,29 @@ console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // çıktı farklı
1. y'nin değerini hesaplayın (y = x<sup>2</sup> + 6x + 9). Farklı x değerleri kullanmayı deneyin ve y'nin hangi x değerinin 0 olduğunu bulun. 1. y'nin değerini hesaplayın (y = x<sup>2</sup> + 6x + 9). Farklı x değerleri kullanmayı deneyin ve y'nin hangi x değerinin 0 olduğunu bulun.
1. Kullanıcıdan saat ve saat başına oran girmesini isteyen bir komut dosyası yazın. Kişinin ücretini hesapla? 1. Kullanıcıdan saat ve saat başına oran girmesini isteyen bir komut dosyası yazın. Kişinin ücretini hesapla?
```sh ```sh
Enter hours: 40 Enter hours: 40
Enter rate per hour: 28 Enter rate per hour: 28
Your weekly earning is 1120 Your weekly earning is 1120
``` ```
1. Adınızın uzunluğu 7'den büyükse, adınız uzun, yoksa adınızın kısa olduğunu söyleyin. 1. Adınızın uzunluğu 7'den büyükse, adınız uzun, yoksa adınızın kısa olduğunu söyleyin.
1. Adınızın uzunluğunu ve soyadınızın uzunluğunu karşılaştırın ve bu çıktıyı almalısınız. 1. Adınızın uzunluğunu ve soyadınızın uzunluğunu karşılaştırın ve bu çıktıyı almalısınız.
```js ```js
let firstName = 'Asabeneh' let firstName = "Asabeneh";
let lastName = 'Yetayeh' let lastName = "Yetayeh";
``` ```
```sh ```sh
Your first name, Asabeneh is longer than your family name, Yetayeh Your first name, Asabeneh is longer than your family name, Yetayeh
``` ```
1. İki değişken _myAge_ ve _yourAge_ bildirin ve bunlara başlangıç değerleri ile myAge ve yourAge atayın. 1. İki değişken _myAge_ ve _yourAge_ bildirin ve bunlara başlangıç değerleri ile myAge ve yourAge atayın.
```js ```js
let myAge = 250 let myAge = 250;
let yourAge = 25 let yourAge = 25;
``` ```
```sh ```sh
@ -608,14 +605,15 @@ console.log(`${date}/${month}/${year} ${hours}:${minutes}`) // çıktı farklı
``` ```
1. İstemi kullanarak, kullanıcının doğduğu yılı alır ve kullanıcı 18 veya daha büyükse, kullanıcıya belirli bir süre beklemesini söylemediği takdirde, kullanıcının araba kullanmasına izin verir. 1. İstemi kullanarak, kullanıcının doğduğu yılı alır ve kullanıcı 18 veya daha büyükse, kullanıcıya belirli bir süre beklemesini söylemediği takdirde, kullanıcının araba kullanmasına izin verir.
```sh
Enter birth year: 1995 ```sh
You are 25. You are old enough to drive
Enter birth year: 1995
You are 25. You are old enough to drive
Enter birth year: 2005 Enter birth year: 2005
You are 15. You will be allowed to drive after 3 years. You are 15. You will be allowed to drive after 3 years.
``` ```
1. Kullanıcıdan yıl sayısını girmesini isteyen bir komut dosyası yazın. Bir kişinin yaşayabileceği saniye sayısını hesaplayın. Birinin sadece yüz yıl yaşadığını varsayalım 1. Kullanıcıdan yıl sayısını girmesini isteyen bir komut dosyası yazın. Bir kişinin yaşayabileceği saniye sayısını hesaplayın. Birinin sadece yüz yıl yaşadığını varsayalım

Loading…
Cancel
Save