This commit is contained in:
Ilya Kantor 2015-06-09 13:26:46 +03:00
parent cd23e7d953
commit bdb98d1ce9
5 changed files with 6 additions and 90 deletions

View file

@ -181,9 +181,9 @@
</dd>
</dl>
[warn header="Либо `async` либо `defer`"]
Одновременно указывать `async` и `defer` не имеет смысла, в этом случае браузер использует только `async`.
[/warn]
[smart header="`async` вместе с `defer`"]
При одновременном указании `async` и `defer` в современных браузерах будет использован только `async`, в IE9- -- только `defer` (не понимает `async`).
[/smart]
[warn header="Атрибуты `async/defer` -- только для внешних скриптов"]
Атрибуты `async/defer` работают только в том случае, если назначены на внешние скрипты, т.е. имеющие `src`.

View file

@ -1,43 +0,0 @@
Разница в поведении станет очевидной, если рассмотреть код внутри функции.
Поведение будет различным, если управление каким-то образом выпрыгнет из `try..catch`.
Например, `finally` сработает после `return`:
```js
function f() {
try {
...
*!*
return result;
*/!*
} catch (e) {
...
} finally {
очистить ресурсы
}
}
```
Или же управление может выпрыгнуть из-за `throw`:
```js
function f() {
try {
...
} catch (e) {
...
if(не умею обрабатывать эту ошибку) {
*!*
throw e;
*/!*
}
} finally {
очистить ресурсы
}
}
```
В этих случаях именно `finally` гарантирует выполнение кода до окончания работы `f`, просто код не будет вызван.

View file

@ -1,43 +0,0 @@
# Finally или просто код?
[importance 5]
Сравните два фрагмента кода.
<ol>
<li>Первый использует `finally` для выполнения кода по выходу из `try..catch`:
```js
try {
начать работу
работать
} catch (e) {
обработать ошибку
} finally {
*!*
финализация: завершить работу
*/!*
}
```
</li>
<li>Второй фрагмент просто ставит очистку ресурсов за `try..catch`:
```js
try {
начать работу
} catch (e) {
обработать ошибку
}
*!*
финализация: завершить работу
*/!*
```
</li>
</ol>
Нужно, чтобы код финализации всегда выполнялся при выходе из блока `try..catch` и, таким образом, заканчивал начатую работу. Имеет ли здесь `finally` какое-то преимущество или оба фрагмента работают одинаково?
Если имеет, то дайте пример когда код с `finally` работает верно, а без -- неверно.

View file

@ -5,6 +5,7 @@
Улучшите готовый код кофеварки, который дан ниже: добавьте в кофеварку *публичный* метод `stop()`, который будет останавливать кипячение (через `clearTimeout`).
```js
//+ run
function CoffeeMachine(power) {
this.waterAmount = 0;
@ -38,4 +39,5 @@ coffeeMachine.stop(); // кофе приготовлен не будет
```
P.S. Текущую температуру воды вычислять и хранить не требуется.
P.P.S. При решении вам, скорее всего, понадобится добавить *приватное* свойство `timerId`, которое будет хранить текущий таймер.

View file

@ -115,7 +115,7 @@ alert( "100 10 1".match(/\d0+/g) ); // 100, 10
В действии:
```js
//+ run
alert( "0 1 12.345 7890".match(/\d+\.\d+/g) ); // 123.45
alert( "0 1 12.345 7890".match(/\d+\.\d+/g) ); // 12.345
```
</dd>