Merge pull request #454 from atomiks/defer

[ADD: `defer.md`] defer
This commit is contained in:
Angelos Chalaris
2018-01-02 10:41:26 +02:00
committed by GitHub
2 changed files with 20 additions and 0 deletions

19
snippets/defer.md Normal file
View File

@ -0,0 +1,19 @@
### defer
Defers invoking a function until the current call stack has cleared.
Use `setTimeout()` with a timeout of 1ms to add a new event to the browser event queue and allow the rendering engine to complete its work. Use the spread (`...`) operator to supply the function with an arbitrary number of arguments.
```js
const defer = (fn, ...args) => setTimeout(fn, 1, ...args);
```
```js
// Example A:
defer(console.log, 'a'), console.log('b'); // logs 'b' then 'a'
// Example B:
document.querySelector('#someElement').innerHTML = 'Hello';
longRunningFunction(); // the browser will not update the HTML until this has finished
defer(longRunningFunction); // the browser will update the HTML then run the function
```