|  | 7 年之前 | |
|---|---|---|
| .. | ||
| test | 7 年之前 | |
| .npmignore | 7 年之前 | |
| .travis.yml | 7 年之前 | |
| LICENSE | 7 年之前 | |
| README.md | 7 年之前 | |
| index.js | 7 年之前 | |
| package.json | 7 年之前 | |
node.js through stream that emits a unique stream of objects based on criteria
Install via npm:
$ npm install unique-stream
var unique = require('unique-stream')
  , Stream = require('stream');
// return a stream of 3 identical objects
function makeStreamOfObjects() {
  var s = new Stream;
  s.readable = true;
  var count = 3;
  for (var i = 0; i < 3; i++) {
    setImmediate(function () {
      s.emit('data', { name: 'Bob', number: 123 });
      --count && end();
    });
  }
  function end() {
    s.emit('end');
  }
  return s;
}
// Will only print out one object as the rest are dupes. (Uses JSON.stringify)
makeStreamOfObjects()
  .pipe(unique())
  .on('data', console.log);
// Use name as the key field to dedupe on. Will only print one object
makeStreamOfObjects()
  .pipe(unique('name'))
  .on('data', console.log);
// Use a custom function to dedupe on. Use the 'number' field. Will only print one object.
makeStreamOfObjects()
  .pipe(function (data) {
    return data.number;
  })
  .on('data', console.log);
The reason I wrote this was to dedupe multiple object streams:
var aggregator = unique();
// Stream 1
makeStreamOfObjects()
  .pipe(aggregator);
// Stream 2
makeStreamOfObjects()
  .pipe(aggregator);
// Stream 3
makeStreamOfObjects()
  .pipe(aggregator);
aggregator.on('data', console.log);