diff --git a/README.md b/README.md
index ec2ea9f30..87b3253ec 100644
--- a/README.md
+++ b/README.md
@@ -162,6 +162,7 @@ average(1, 2, 3);
* [`unzip`](#unzip)
* [`unzipWith`](#unzipwith-)
* [`without`](#without)
+* [`xProd`](#xprod)
* [`zip`](#zip)
* [`zipObject`](#zipobject)
* [`zipWith`](#zipwith-)
@@ -2226,6 +2227,28 @@ without([2, 1, 2, 3], 1, 2); // [3]
[⬆ Back to top](#table-of-contents)
+### xProd
+
+Creates a new array out of the two supplied by creating each possible pair from the arrays.
+
+Use `Array.map()` to produce every possible pair from the elements of the two arrays.
+
+```js
+const xProd = (a, b) => a.map(x => b.map(y => [x, y]));
+```
+
+
+Examples
+
+```js
+xProd([1, 2], ['a', 'b']); // [[1, 'a'], [1, 'b'], [2, 'a'], [2, 'b']]
+```
+
+
+
+ [⬆ Back to top](#table-of-contents)
+
+
### zip
Creates an array of elements, grouped based on the position in the original arrays.
diff --git a/docs/index.html b/docs/index.html
index 1a7e18bfc..39a9ae8a6 100644
--- a/docs/index.html
+++ b/docs/index.html
@@ -50,7 +50,7 @@
scrollToTop();
}
}, false);
- }
30 seconds of code Curated collection of useful JavaScript snippets that you can understand in 30 seconds or less.
Adapter
ary
Creates a function that accepts up to n arguments, ignoring any additional arguments.
Call the provided function, fn, with up to n arguments, using Array.slice(0,n) and the spread operator (...).
Creates an array of elements, grouped based on the position in the original arrays.
Use Math.max.apply() to get the longest array in the arguments. Creates an array with that length as return value and use Array.from() with a map-function to create an array of grouped elements. If lengths of the argument-arrays vary, undefined is used where no value could be found.