Package Exports
- type-reverse
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (type-reverse) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
type-reverse
🦄 Lightweight reverse utility around strings, arrays, numbers and more.
Install
$ npm install --save type-reverseUsage
const reverse = require('type-reverse')or...
import reverse from 'type-reverse'API
reverse( input[, options][, callback] )
Params
input{String|Number|Array|Set}options{?Object}callback{?Function}returns{*}
reverse('pizza')
//=> azzipWorks with numbers too.
reverse(1234)
//=> 4321Reversing arrays...
When JavaScript's Array#reverse method is used, the original array is mutated, as in, the indexes of the elements are changed. On the other hand, this utility adopts the non-destructive array reversal method, which means the reverse() function doesn't mutate the array; it just returns the reversed array and still maintains the indexes of the elements in the original array.
native reverse...
const arr = [1, 2, 3]
arr.reverse() //=> [3, 2, 1]Oops, we lost the indexes of elements in the initial array...
console.log(arr) //=> [3, 2, 1]vs...
🦄 to the rescue...
const arr = [1, 2, 3]
reverse(arr) //=> [3, 2, 1]Yay! arr is not mutated. The indexes of its elements are still maintained...
console.log(arr) //=> [1, 2, 3]Sets
If you've been wondering how to reverse Sets in JavaScript, here's it! The core reverse function can take in a Set as the input and then return the reversed Set...
const set = new Set([5, 4, 3, 4, 5])
reverse(set) //=> Set { 3, 4, 5 }options
options is the second parameter to the function call and it is an object with two available properties. It can also take in a falsy value which would implicity get converted to an empty object.
invert: {String}
This property defaults to index and applies to strings and numbers only.
reverse(/*...*/, {
invert: '[index|word|sign]'
})index- interchanges the indexes of characters in the input...reverse(12345, { invert: 'index' }) //=> 54321 reverse('of... unicorns', { invert: 'index' }) //=> snrocinu ...fo
sign- inverts the sign in a number...reverse(1234, { invert: 'sign' }) //=> -1234
word- swaps the location of words in a string...reverse('of... unicorns', { invert: 'word' }) //=> unicorns of...
preserveZeros: {Boolean}
This property defaults to true. It specifies whether to enforce preceding zeros in the result of a number that contains trailing zeros. See #3 for more info. Note that the result gets converted to a string. Disabling it would look like this...
reverse(240, { preserveZeros: false }) //=> 42callback: {Function}
The callback takes in a function with two optional parameters that represent input and result respectively.
input- the initial input that was passed into the functionresult- the output from reversing the input
const text = 'dog'
reverse(text, null, function(intitial, result) {
return intitial + ' was changed to ' + result
}) //=> dog was changed to godLimits
Did you just try to reverse a reaally huge number? Unfortunately, this utility doesn't support very large numbers. Trying to do so with this utility would throw a TypeError.
Author
Olaolu Olawuyi
License
MIT © Olaolu Olawuyi