Skip to content

Data types > Methods of primitives (updated from origin) #11

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

Merged
merged 5 commits into from
May 9, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -9,23 +9,18 @@ str.test = 5; // (*)
alert(str.test);
```

Ви можете отримати два результати:
1. `undefined`
2. помилку.
В залежності від того, втановлений у вас `use strict` чи ні, результати будуть наступними:
1. `undefined` (без строгого режиму)
2. Помилка (строгий режим)

Чому? Давайте повторимо те, що відбувається в рядку `(*)`:
Чому? Давайте повторимо те, що відбувається в рядку, який позначено `(*)`:

1. Коли ми намагаємося отримати доступ до `str`, створюється "об'єкт обгортка".
2. Операція з властивістю здійснюється в ній. Отже, об'єкт отримує властивість `test`.
3. Операція закінчується, і "об'єкт обгортка" зникає.

Отже, на останньому рядку `str` не має властивості. Для кожної операції створюється новий об'єкт обгортка.

Деякі браузери можуть вирішити додатково обмежити програміста і взагалі заборонити присвоювати властивості примітивам. Тому на практиці ми можемо бачити помилки в рядку `(*)`. Але це трохи відрізняється від специфікації.
2. В строгому режимі, спроба запису викличе помилку.
3. В іншому випадку операція здійсниться і об'єкт отримає властивість `test`, але після цього "об'єкт обгортка" зникне.

Отже, якщо код виконується не в строгому режимі, на останньому рядку `str` не матиме властивості `test`.

**Цей приклад чітко показує, що примітиви не є об'єктами.**

Вони просто не можуть зберігати дані.

Всі операції з властивостями/методами виконуються за допомогою тимчасових об'єктів.
Вони не можуть зберігати додаткові данні.
12 changes: 6 additions & 6 deletions 1-js/05-data-types/01-primitives-methods/article.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ JavaScript дозволяє працювати з примітивами (ряд
Об'єкт

- можна зберігати декілька значень як властивості.
- може бути створений за допомогою `{}`, наприклад: `{name: "John", age: 30}`. В JavaScript існують й інші об'єкти; функції - це теж об'єкти.
- може бути створений за допомогою `{}`, наприклад: `{name: "John", age: 30}`. В JavaScript існують й інші об'єкти: функції - це теж об'єкти.

Одна з цікавих речей щодо об'єктів полягає в тому, що ми можемо зберігати функцію як одну з його властивостей.

Expand Down Expand Up @@ -48,7 +48,7 @@ john.sayHi(); // Привіт друже!

1. Примітиви залишаються примітивами. Лише значення, як хотіли.
2. JavaScript дозволяє отримати доступ до методів та властивостей рядків, чисел, булеанів та символів.
3. Коли це трапляється, створюється спеціальний "об'єкт обгортка" з додатковою функціональністю, та потім він знищується.
3. Для цього створюється спеціальний "об'єкт обгортка" з додатковою функціональністю, та потім він знищується.

Для кожного примітиву створюється своя "обгортка": `String`, `Number`, `Boolean` та `Symbol`. Отже, вони містять різні набори методів.

Expand Down Expand Up @@ -91,18 +91,18 @@ alert( n.toFixed(2) ); // 1.23
Наприклад:

```js run
alert( typeof 1 ); // "number"
alert( typeof 0 ); // "number"

alert( typeof new Number(1) ); // "object"!
alert( typeof new Number(0) ); // "object"!
```

та завдяки тому що `zero` об'єкт, ми побачимо алерт:
Об'єкти завжди повертають `true` в `if`, отже ми побачимо алерт:

```js run
let zero = new Number(0);

if (zero) { // zero є true, тому що це об'єкт
alert( "zero є true?!?" );
alert( "zero є true!?!" );
}
```

Expand Down