oef/node_modules/es6-set
2019-11-04 15:00:46 +01:00
..
ext First commit 2019-11-04 15:00:46 +01:00
lib First commit 2019-11-04 15:00:46 +01:00
node_modules/es6-symbol First commit 2019-11-04 15:00:46 +01:00
primitive First commit 2019-11-04 15:00:46 +01:00
test First commit 2019-11-04 15:00:46 +01:00
.lint First commit 2019-11-04 15:00:46 +01:00
.npmignore First commit 2019-11-04 15:00:46 +01:00
.travis.yml First commit 2019-11-04 15:00:46 +01:00
CHANGES First commit 2019-11-04 15:00:46 +01:00
implement.js First commit 2019-11-04 15:00:46 +01:00
index.js First commit 2019-11-04 15:00:46 +01:00
is-implemented.js First commit 2019-11-04 15:00:46 +01:00
is-native-implemented.js First commit 2019-11-04 15:00:46 +01:00
is-set.js First commit 2019-11-04 15:00:46 +01:00
LICENSE First commit 2019-11-04 15:00:46 +01:00
package.json First commit 2019-11-04 15:00:46 +01:00
polyfill.js First commit 2019-11-04 15:00:46 +01:00
README.md First commit 2019-11-04 15:00:46 +01:00
valid-set.js First commit 2019-11-04 15:00:46 +01:00

es6-set

Set collection as specified in ECMAScript6

Warning:
v0.1 version does not ensure O(1) algorithm complexity (but O(n)). This shortcoming will be addressed in v1.0

Usage

If you want to make sure your environment implements Set, do:

require('es6-set/implement');

If you'd like to use native version when it exists and fallback to polyfill if it doesn't, but without implementing Set on global scope, do:

var Set = require('es6-set');

If you strictly want to use polyfill even if native Set exists, do:

var Set = require('es6-set/polyfill');

Installation

$ npm install es6-set

To port it to Browser or any other (non CJS) environment, use your favorite CJS bundler. No favorite yet? Try: Browserify, Webmake or Webpack

API

Best is to refer to specification. Still if you want quick look, follow examples:

var Set = require('es6-set');

var set = new Set(['raz', 'dwa', {}]);

set.size;          // 3
set.has('raz');    // true
set.has('foo');    // false
set.add('foo');    // set
set.size           // 4
set.has('foo');    // true
set.has('dwa');    // true
set.delete('dwa'); // true
set.size;          // 3

set.forEach(function (value) {
 // 'raz', {}, 'foo' iterated
});

// FF nightly only:
for (value of set) {
 // 'raz', {}, 'foo' iterated
}

var iterator = set.values();

iterator.next(); // { done: false, value: 'raz' }
iterator.next(); // { done: false, value: {} }
iterator.next(); // { done: false, value: 'foo' }
iterator.next(); // { done: true, value: undefined }

set.clear(); // undefined
set.size; // 0

Tests Build Status

$ npm test