DOM events
0-N values
Animations
cancelable
AJAX
1 value
WebSockets
0-N values
ServerSendEvents
0-N values
Observable
+
Iterator pattern
=
Observer pattern
fs.readdir(source, function (err, files) {
if (err) {
console.log('Error finding files: ' + err)
} else {
files.forEach(function (filename, fileIndex) {
console.log(filename)
gm(source + filename).size(function (err, values) {
if (err) {
console.log('Error identifying file size: ' + err)
} else {
console.log(filename + ' : ' + values)
aspect = (values.width / values.height)
widths.forEach(function (width, widthIndex) {
height = Math.round(width / aspect)
console.log('resizing ' + filename + 'to ' + height + 'x' + height)
this.resize(width, height).write(dest + 'w' + width + '_' + filename, function(err) {
if (err) console.log('Error writing file: ' + err)
})
}.bind(this))
}
})
})
}
})
Operators
Observables
Schedulers
+
+
=
RxJS
There are methods on Observables that allow you to compose new observables.
3 calls?
Ben Lesh about Hot vs Cold observables
Suggestion widget with "hot" observable: