Add mapString, fix dig

This commit is contained in:
Angelos Chalaris
2018-07-14 10:59:56 +03:00
parent bcced2bed7
commit 2c47f76676
7 changed files with 1601 additions and 1551 deletions

View File

@ -5,7 +5,7 @@ Returns the target value in a nested JSON object, based on the given key.
Use the `in` operator to check if `target` exists in `obj`. Use the `in` operator to check if `target` exists in `obj`.
If found, return the value of `obj[target]`, otherwise use `Object.values(obj)` and `Array.reduce()` to recursively call `dig` on each nested object until the first matching key/value pair is found. If found, return the value of `obj[target]`, otherwise use `Object.values(obj)` and `Array.reduce()` to recursively call `dig` on each nested object until the first matching key/value pair is found.
``` ```js
const dig = (obj, target) => const dig = (obj, target) =>
target in obj target in obj
? obj[target] ? obj[target]
@ -17,7 +17,7 @@ const dig = (obj, target) =>
}, undefined); }, undefined);
``` ```
``` ```js
const data = { const data = {
level1:{ level1:{
level2:{ level2:{

16
snippets/mapString.md Normal file
View File

@ -0,0 +1,16 @@
### mapString
Creates a new string with the results of calling a provided function on every character in the calling string.
Use `String.split('')` and `Array.map()` to call the provided function, `fn`, for each character in `str`.
Use `Array.join('')` to recombine the array of characters into a string.
The callback function, `fn`, takes three arguments (the current character, the index of the current character and the string `mapString` was called upon).
```js
const mapString = (str, fn) =>
str.split('').map((c, i) => fn(c, i, str)).join('');
```
```js
mapString('lorem ipsum', c => c.toUpperCase()); // 'LOREM IPSUM'
```

View File

@ -162,6 +162,7 @@ lowercaseKeys:object
luhnCheck:math,utility luhnCheck:math,utility
mapKeys:object,function mapKeys:object,function
mapObject:array,object,advanced mapObject:array,object,advanced
mapString:string,array,function,utility
mapValues:object,function mapValues:object,function
mask:string,utility,regexp mask:string,utility,regexp
matches:object,type matches:object,type

View File

@ -1,15 +1,10 @@
const dig = (obj, target) => const dig = (obj, target) =>
target in obj target in obj
? obj[target] ? obj[target]
: Object : Object
.values(obj) .values(obj)
.reduce((acc, val) => { .reduce((acc, val) => {
if (acc !== undefined) { if (acc !== undefined) return acc;
return acc; if (typeof val === 'object') return dig(val, target);
} }, undefined);
if (typeof val === "object") {
return dig(val, target);
}
}, undefined);
module.exports = dig; module.exports = dig;

View File

@ -0,0 +1,3 @@
const mapString = (str, fn) =>
str.split('').map((c, i) => fn(c, i, str)).join('');
module.exports = mapString;

View File

@ -0,0 +1,20 @@
const expect = require('expect');
const mapString = require('./mapString.js');
test('mapString is a Function', () => {
expect(mapString).toBeInstanceOf(Function);
});
test('mapString returns a capitalized string', () => {
expect(mapString('test', c => c.toUpperCase())).toBe('TEST');
});
const indexMapper = (c, i) => `${c}[${i}]`;
test('mapString can deal with indexes', () => {
expect(mapString('test', indexMapper)).toBe('t[0]e[1]s[2]t[3]');
});
const fullStringMapper = (c, i, str) => `{${str}}${c}[${i}]`;
test('mapString can deal with the full string', () => {
expect(mapString('test', fullStringMapper)).toBe('{test}t[0]{test}e[1]{test}s[2]{test}t[3]');
});

File diff suppressed because it is too large Load Diff