Skip to content

Commit c077b25

Browse files
authored
Merge pull request #11 from JavaScript-Basic-OTUS/lesson15
lesson15: добавил новый урок
2 parents 2ab4923 + 2bb6d85 commit c077b25

File tree

1 file changed

+192
-1
lines changed

1 file changed

+192
-1
lines changed

lessons/lesson15/lesson.md

Lines changed: 192 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1 +1,192 @@
1-
# Lesson 15
1+
---
2+
title: Занятие 4.1
3+
description: Базовое использование API и JavaScript. Как работать с DOM и другими доступными API
4+
---
5+
6+
# OTUS
7+
8+
## Javascript Basic
9+
10+
<!--v-->
11+
12+
### Вопросы?
13+
14+
<!--s-->
15+
16+
### Базовое использование API и JavaScript.
17+
18+
#### Как работать с DOM и другими доступными API
19+
20+
<!-- s -->
21+
22+
### API
23+
24+
<!-- v -->
25+
26+
**API** (**программный интерфейс** приложения, интерфейс прикладного программирования) (англ. application programming interface, API [эй-пи-ай]) — [описание способов (набор классов, процедур, функций, структур или констант), которыми одна компьютерная программа может взаимодействовать с другой программой](https://ru.wikipedia.org/wiki/API).
27+
28+
<!-- v -->
29+
30+
Под API можно понимать любые методы и свойства, которые не относятся непосредственно к конструкциям языка
31+
32+
<!-- v -->
33+
34+
Каким API пользуются разработчики?
35+
36+
- встроенное в язык
37+
- встроенное в среду исполнения
38+
- предоставляемое дополнительными пакетами
39+
- предоставляемое сторонними сервисами (доступ к которым делается посредством API среды исполнения или дополнительных пакетов)
40+
41+
<!-- v -->
42+
43+
Единственный способ узнать про API - читать документацию (статьи, книги, смотреть доклады).
44+
45+
Единственный способ научиться пользоваться API - работать с API.
46+
47+
<!-- v -->
48+
49+
[Интерфейсы веб API](https://developer.mozilla.org/ru/docs/Web/API)
50+
51+
<!-- v -->
52+
53+
Что мы посмотрим:
54+
55+
- работу со страницей (изменение страницы и чтение данных от пользователя)
56+
- сохранение данных
57+
- работу удаленными ресурсами (следующее занятие)
58+
59+
<!-- v -->
60+
61+
### Вопросы?
62+
63+
<!-- s -->
64+
65+
### Работа со страницей
66+
67+
<!-- v -->
68+
69+
**DOM** - Document Object Model.
70+
71+
API браузера для работы с веб страницей и ее элементами. Представлено глобальными объектами `window`, `document` и API для работы с HTML элементами (создание, удаление, редактирование).
72+
73+
<!-- v -->
74+
75+
Поиск элементов на странице:
76+
77+
- `document.getElementById`
78+
- `document.getElementsByTagName`
79+
- `document.getElementsByClassName`
80+
- `document.querySelector`
81+
- `document.querySelectoAll`
82+
83+
[Document API](https://developer.mozilla.org/ru/docs/Web/API/Document) и [описание селекторов](http://htmlbook.ru/css/selector)([1](http://sauron.org.ua/post/1254), [2](https://migo.com.ua/blog/css/css-selectory-kotorue-dolzhen-znat-kazhduy.html), [3](https://www.exlab.net/files/tools/sheets/css/css.pdf))
84+
85+
<!-- v -->
86+
87+
Создание и изменение элементов. Два варианта:
88+
89+
- использование `innerHTML` и работа с элементами как со строкой HTML
90+
- использование `document.createElement` и работа с элементами как с узлами дерева
91+
92+
<!-- v -->
93+
94+
Для подписки на события элементов есть 3 варианта:
95+
96+
- `addEventListener` <-- мы будем использовать вот этот
97+
- `onclick="func()"`
98+
- `el.onclick=func`
99+
100+
<!-- v -->
101+
102+
[Пример](https://codesandbox.io/s/github/vvscode/otus--javascript-basic/tree/lesson04/lessons/lesson04/code/DOMExamples)
103+
104+
<!-- v -->
105+
106+
[Практика](https://codesandbox.io/s/github/vvscode/otus--javascript-basic/tree/lesson04/lessons/lesson04/code/DOMExamplesPractice)
107+
108+
<!-- v -->
109+
110+
### Вопросы?
111+
112+
<!-- s -->
113+
114+
### [Сохранение данных](https://learn.javascript.ru/data-storage)
115+
116+
<!-- v -->
117+
118+
- [IndexedDB](https://developer.mozilla.org/ru/docs/Web/API/IndexedDB_API)
119+
- [Storage](https://developer.mozilla.org/ru/docs/Web/API/Storage) (Local Storage / Session Storage)
120+
- [Cookies](https://developer.mozilla.org/ru/docs/Web/API/Document/cookie)
121+
122+
<!-- v -->
123+
124+
DOM Storage полезен для хранения небольшого количества данных, но он менее выгоден для большого числа структурированных данных (тк работает со строками). IndexedDB предоставляет решение для клиентского хранилища большого объема структурированных данных, включая файлы/blobs.
125+
126+
<!-- v -->
127+
128+
```js [1-30]
129+
// Пример работы с local storage
130+
const key = "someKey";
131+
const value = "someValue";
132+
localStorage.setItem(key, value);
133+
console.log(localStorage.getItem(key));
134+
localStorage.removeItem(key);
135+
console.log(localStorage.getItem(key)); // null
136+
```
137+
138+
<!-- v -->
139+
140+
```js [1-30]
141+
// ВАЖНО! работает только со строками
142+
const key = "someKey";
143+
const value = 1;
144+
localStorage.setItem(key, value);
145+
console.log(localStorage.getItem(key)); // "1"
146+
```
147+
148+
<!-- v -->
149+
150+
```js [1-30]
151+
// для работы с другими типами данных
152+
// обычно используют сериализацию
153+
const value1 = 1;
154+
const value2 = { name: "Bob" };
155+
localStorage.setItem("value1", JSON.stringify(value1));
156+
localStorage.setItem("value2", JSON.stringify(value2));
157+
console.log(JSON.parse(localStorage.getItem("value1"))); // 1
158+
console.log(JSON.parse(localStorage.getItem("value2"))); // { name: 'Bob' }
159+
```
160+
161+
<!-- v -->
162+
163+
Важно помнить, что если значения нет - вы получите `null` и десериализация сломается. Поэтому перед вызовом `parse` нужно проверять данные.
164+
165+
### Вопросы?
166+
167+
<!-- v -->
168+
169+
[Практика](https://codesandbox.io/s/github/vvscode/otus--javascript-basic/tree/lesson04/lessons/lesson04/code/dataStoragePractice)
170+
171+
<!-- v -->
172+
173+
### Вопросы?
174+
175+
<!-- s -->
176+
177+
#### Дополнительные материалы
178+
179+
<!-- v -->
180+
181+
1. [Путеводитель по JavaScript Promise для новичков](https://habr.com/ru/company/zerotech/blog/317256/)
182+
1. [Чистый код на Javascript](https://github.com/BoryaMogila/clean-code-javascript-ru/)
183+
184+
<!-- v -->
185+
186+
#### Вопросы для самопроверки
187+
188+
1. Чем куки (cookie) отличаются от localStorage ?
189+
190+
2. Как реализовать подписку на клик по кнопке, которая отработает только один раз? ( с примером кода )
191+
192+
3. Что такое KISS, DRY, YAGNI?

0 commit comments

Comments
 (0)