Javascript port of Illuminate Collections
The Collection
class provides a fluent, convenient wrapper for working with arrays of data. For example, check out the following code. We'll use the collect
helper to create a new collection instance from the array, run the toUpperCase
function on each element, and then remove all empty elements:
import { collect } from 'illuminate-collections';
const collection = collect(['taylor', 'abigail'])
.map((name) => name.toUpperCase());
console.log(collection.all());
// ['TAYLOR', 'ABIGAIL']
npm install illuminate-collections
This project is freely distributable under the terms of the MIT license.
As mentioned above, the collect
helper returns a new Collection
instance for the given array or object. So, creating a collection is as simple as:
import { collect } from 'illuminate-collections';
const collection = collect([1, 2, 3]);
For the majority of the remaining collection documentation, we'll discuss each method available on the Collection
class. Remember, all of these methods may be chained to fluently manipulate the underlying array. Furthermore, almost every method returns a new Collection
instance, allowing you to preserve the original copy of the collection when necessary:
all | chunk | collect |
average | chunkWhile | combine |
avg | collapse | contains |
Returns the underlying array/object represented by the collection:
collect([1, 2, 3]).all();
// [1, 2, 3]
Alias for the avg
method.
Returns the average value of a given key:
const average = collect([
{'foo': 10},
{'foo': 10},
{'foo': 20},
{'foo': 40},
]).avg('foo');
console.log(average);
// average = 20
const average = collect([1, 1, 2, 4]).avg();
console.log(average);
// average = 2
Breaks the collection into multiple, smaller collections of a given size:
const collection = collect([1, 2, 3, 4, 5, 6, 7]);
const chunks = collection.chunk(4);
console.log(chunks.all());
// [[1, 2, 3, 4], [5, 6, 7]]
Breaks the collection into multiple, smaller collections based on the evaluation of the given callback. The chunk
variable passed to the closure may be used to inspect the previous element:
const collection = collect('AABBCCCD');
const chunks = collection.chunkWhile((value, key, chunk) => value === chunk.last());
console.log(chunks.all());
// [['A', 'A'], ['B', 'B'], ['C', 'C', 'C'], ['D']]