Async Mindset Snippets
nodejs async module snippets designed to improve your coding style
Details
Installs
- Total 737
- Win 425
- Mac 185
- Linux 127
Sep 29 | Sep 28 | Sep 27 | Sep 26 | Sep 25 | Sep 24 | Sep 23 | Sep 22 | Sep 21 | Sep 20 | Sep 19 | Sep 18 | Sep 17 | Sep 16 | Sep 15 | Sep 14 | Sep 13 | Sep 12 | Sep 11 | Sep 10 | Sep 9 | Sep 8 | Sep 7 | Sep 6 | Sep 5 | Sep 4 | Sep 3 | Sep 2 | Sep 1 | Aug 31 | Aug 30 | Aug 29 | Aug 28 | Aug 27 | Aug 26 | Aug 25 | Aug 24 | Aug 23 | Aug 22 | Aug 21 | Aug 20 | Aug 19 | Aug 18 | Aug 17 | Aug 16 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Windows | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
Mac | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
Linux | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
Readme
- Source
- raw.githubusercontent.com
Examples
series TAB ->
return async.series({
nameOfStepOne: function(callback) {
// After naming step one and tabbing again, you are here
}
});
step TAB ->
return async.series({
stepOne: function(callback) {
...
},
stepTwo: function(callback) {
// Position yourself after step one, type "step"
// and hit tab; you are prompted to name "stepTwo".
// Hit tab again and you're here
}
});
**each TAB ->
**
“javascript
return async.eachSeries(myArray, function(item, callback) {
// After typing myArray and pressing tab again, you are here
}, callback);
**`err TAB ->`**
```javascript
if (err) {
return callback(err);
}
**done TAB ->
**
”javascript
return callback(null);
**`skip TAB ->`**
```javascript
// Safely invoke callback when we didn't
// do anything async
return setImmediate(callback);
**skipr TAB ->
**
“javascript
// Safely invoke callback with some data when we
// didn't anything async
return setImmediate(_.partial(callback, null, data));
**`whil TAB ->`**
```javascript
var done = false;
return async.whilst(
function() { return !done; },
function(callback) {
// You start typing again here
}, callback
);
Your inner function keeps getting called until you set done
to true.
Philosophy
If you're gonna code with callbacks, you gotta use the async module. Otherwise you're writing spaghetti code and infinitely nested curly braces.
The async module solves this problem, but it takes a lot of typing and that leads to mistakes. That's where these snippets come in.
These snippets have aggressively short keywords to make it easy to drill them into your fingers and improve your node programming style permanently.
All of these snippets start with return
to avoid accidentally falling through to other code. Calling another function that takes a callback does not stop the execution of your function unles you return.
The each
snippet deliberately uses eachSeries
. async.each
is usually a mistake because you haven't thought about the consequences of (100? 1,000? 1,000,000?) things happening at once.
Switch your code to eachLimit
later if you have a rational reason to believe you can handle more than one at a time safely.
You should always use skip
if you have not done any asynchronous work yet in your function and you need to invoke a callback asynchronously to avoid crashing the JavaScript stack. If you don't use skip
(which calls setImmediate
), your code will seem fine until one day you have a few hundred items and the JavaScript stack crashes. This is especially true with async.eachSeries
.
Credits
These snippets were developed to support our work at P'unk Avenue.