reverse-iterable-array
The ReverseIterableArray
object is a reverse-iterable array implementation based on the built-in Array object.
Links:
See also:
Table of Contents
Installation & usage
Browser
Download the UMD bundle file …
curl -O https://raw.githubusercontent.com/kleinfreund/reverse-iterable-array/main/dist/reverse-iterable-array.js
… and import it like this:
const ReverseIterableArray = window.ReverseIterableArray.default
const array = new ReverseIterableArray();
Node
Install the node package as a dependency …
npm install reverse-iterable-array
… and import it like this:
const ReverseIterableArray = require('reverse-iterable-array').default;
const array = new ReverseIterableArray();
Examples
For some live usage examples, clone the repository and run the following:
npm install
npm start
Then, open localhost:8080/examples in a browser.
Tests
In order to run the tests, clone the repository and run the following:
npm install
npm test
Documentation
A ReverseIterableArray
object iterates its elements in insertion or reverse-insertion order — a for...of
loop returns the array’s elements for each iteration.
Constructor
Syntax
new ReverseIterableArray([iterable])
Parameters:
Usage
-
Without arguments
const array = new ReverseIterableArray();
-
With multiple elements
const array = new ReverseIterableArray(1, 2, 3);
-
With a single length argument
const array = new ReverseIterableArray(7);
[Symbol.toStringTag]
The ReverseIterableArray[@@toStringTag]
property has an initial value of “ReverseIterableArray”.
entries()
Returns an iterator containing the [index, element]
pairs for each element in the ReverseIterableArray
object in insertion order.
An iterator containing the same pairs in reverse-insertion order can be obtained with entries().reverseIterator()
.
Syntax
array.entries();
Return value:
A new ReverseIterableArray
iterator object.
Usage
const array = new ReverseIterableArray(1, 2, 4);
const iterator = array.entries();
iterator.next().value;
iterator.next().value;
iterator.next().value;
iterator.next().value;
forEachReverse()
The forEachReverse()
method executes a provided function once per each [index, element]
pair in the ReverseIterableArray
object, in reverse-insertion order.
Syntax
array.forEachReverse(callback[, thisArg]);
Parameters:
- callback: Function to execute for each element.
- thisArg: Value to use as
this
when executing callback
.
Usage
const array = new ReverseIterableArray('a', 'b', 'c');
array.forEachReverse(value => {
console.log(value);
});
array.forEachReverse(function (value, key, arrayReference) {
console.log(key, value, arrayReference.size);
});
iteratorFor()
Returns an iterator containing the [index, element]
pairs for each element in the ReverseIterableArray
object in insertion order starting with the pair specified by the index
parameter.
This allows starting iteration at a specific element in the array.
An iterator containing the same pairs in reverse-insertion order can be obtained with iteratorFor(index).reverseIterator()
.
Syntax
array.iteratorFor(index);
Parameters:
- index: Required. The index of the element to start iterating from.
Return value:
A new ReverseIterableArray
iterator object.
Usage
const array = new ReverseIterableArray('a', 'b', 'c');
const iterator = array.iteratorFor(1);
iterator.next().value;
iterator.next().value;
iterator.next().value;
const reverseIterator = array.iteratorFor(1).reverseIterator();
reverseIterator.next().value;
reverseIterator.next().value;
reverseIterator.next().value;
keys()
Returns an iterator containing the indices for each element in the ReverseIterableArray
object in insertion order.
An iterator containing the same indices in reverse-insertion order can be obtained with keys().reverseIterator()
.
Syntax
array.keys();
Return value:
A new ReverseIterableArray
iterator object.
Usage
const array = new ReverseIterableArray(1, 2, 4);
const iterator = array.keys();
iterator.next().value;
iterator.next().value;
iterator.next().value;
iterator.next().value;
reverseIterator()
In theory, following the semantics of [Symbol.iterator]()
, this should be [Symbol.reverseIterator]()
. However, as a developer, I cannot define a well-known symbol myself and make use of it. In the future, the a proposal like The ReverseIterable Interface, by Lee Byron might make it’s way into the specification. For the time being, the reverseIterator()
function serves the same purpose.
Syntax
array.reverseIterator();
Return value:
The array reverse-iterator function, which is the values().reverseIterator()
function by default.
Usage
const array = new ReverseIterableArray(1, 2, 4);
const iterator = array.reverseIterator();
iterator.next().value;
iterator.next().value;
iterator.next().value;
iterator.next().value;
values()
Returns an iterator containing the elements in the ReverseIterableArray
object in insertion order.
An iterator containing the same elements in reverse-insertion order can be obtained with values().reverseIterator()
.
Syntax
array.values();
Return value:
A new ReverseIterableArray
iterator object.
Usage
const array = new ReverseIterableArray(1, 2, 4);
const iterator = array.values();
iterator.next().value;
iterator.next().value;
iterator.next().value;
iterator.next().value;
[Symbol.iterator]()
Returns the array iterator function. By default, this is the values()
function.
Syntax
array[Symbol.iterator]();
Return value:
The array iterator function, which is the entries()
function by default.
Usage
const array = new ReverseIterableArray(1, 2, 4);
const iterator = array[Symbol.iterator]();
iterator.next().value;
iterator.next().value;
iterator.next().value;
iterator.next().value;
[Symbol.toStringTag]()
The well-known symbol Symbol.toStringTag
is accessed internally when callig Object.prototype.toString()
.
Usage
const array = new ReverseIterableArray();
Object.prototype.toString.call(array)