你们好,首先感谢你们对上一篇文章 127个经常使用的JS代码片断,每段代码花30秒就能看懂(一)的关注,在上篇文章里分享了前21段代码,今天继续分享21段代码,但愿对你的平常工做有所帮助。
javascript
经过递归的形式,将多维数组展平成一维数组。前端
const deepFlatten = arr => [].concat(...arr.map(v => (Array.isArray(v) ? deepFlatten(v) : v)));
deepFlatten([1, [2], [[3], 4], 5]); // [1,2,3,4,5]复制代码
去重对象的属性,若是对象中含有重复的属性,之前面的为准。java
const defaults = (obj, ...defs) => Object.assign({}, obj, ...defs.reverse(), obj);
defaults({ a: 1 }, { b: 2 }, { b: 6 }, { a: 3 }); // { a: 1, b: 2 }复制代码
延迟函数的调用,即异步调用函数。git
const defer = (fn, ...args) => setTimeout(fn, 1, ...args);
defer(console.log, 'a'), console.log('b'); // logs 'b' then 'a'复制代码
此段代码将标准的度数,转换成弧度。数组
const degreesToRads = deg => (deg * Math.PI) / 180.0;
degreesToRads(90.0); // ~1.5708复制代码
此段代码查找两个给定数组的差别,查找出前者数组在后者数组中不存在元素。微信
const difference = (a, b) => {
const s = new Set(b);
return a.filter(x => !s.has(x));
};
difference([1, 2, 3], [1, 2, 4]); // [3]复制代码
经过给定的函数来处理须要对比差别的数组,查找出前者数组在后者数组中不存在元素。异步
const differenceBy = (a, b, fn) => {
const s = new Set(b.map(fn));
return a.filter(x => !s.has(fn(x)));
};
differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor); // [1.2]
differenceBy([{ x: 2 }, { x: 1 }], [{ x: 1 }], v => v.x); // [ { x: 2 } ]复制代码
此段代码按照给定函数逻辑筛选须要对比差别的数组,查找出前者数组在后者数组中不存在元素。函数
const differenceWith = (arr, val, comp) => arr.filter(a => val.findIndex(b => comp(a, b)) === -1);
differenceWith([1, 1.2, 1.5, 3, 0], [1.9, 3, 0], (a, b) => Math.round(a) === Math.round(b));
// [1, 1.2]复制代码
将输入的数字拆分红单个数字组成的数组。post
const digitize = n => [...`${n}`].map(i => parseInt(i));
digitize(431); // [4, 3, 1]复制代码
计算两点之间的距离网站
const distance = (x0, y0, x1, y1) => Math.hypot(x1 - x0, y1 - y0);
distance(1, 1, 2, 3); // 2.23606797749979复制代码
此段代码将给定的数组从左边开始删除 n 个元素
const drop = (arr, n = 1) => arr.slice(n);
drop([1, 2, 3]); // [2,3]
drop([1, 2, 3], 2); // [3]
drop([1, 2, 3], 42); // []复制代码
此段代码将给定的数组从右边开始删除 n 个元素
const dropRight = (arr, n = 1) => arr.slice(0, -n);
dropRight([1, 2, 3]); // [1,2]
dropRight([1, 2, 3], 2); // [1]
dropRight([1, 2, 3], 42); // []复制代码
此段代码将给定的数组按照给定的函数条件从右开始删除,直到当前元素知足函数条件为True时,中止删除,并返回数组剩余元素。
const dropRightWhile = (arr, func) => {
while (arr.length > 0 && !func(arr[arr.length - 1])) arr = arr.slice(0, -1);
return arr;
};
dropRightWhile([1, 2, 3, 4], n => n < 3); // [1, 2]复制代码
按照给的的函数条件筛选数组,不知足函数条件的将从数组中移除。
const dropWhile = (arr, func) => {
while (arr.length > 0 && !func(arr[0])) arr = arr.slice(1);
return arr;
};
dropWhile([1, 2, 3, 4], n => n >= 3); // [3,4]复制代码
接收两个DOM元素对象参数,判断后者是不是前者的子元素。
const elementContains = (parent, child) => parent !== child && parent.contains(child);
elementContains(document.querySelector('head'), document.querySelector('title')); // true
elementContains(document.querySelector('body'), document.querySelector('body')); // false复制代码
移除数组中重复的元素
const filterNonUnique = arr => [ …new Set(arr)];
filterNonUnique([1, 2, 2, 3, 4, 4, 5]); // [1, 2, 3, 4, 5]复制代码
按照给定的函数条件,查找第一个知足条件对象的键值。
const findKey = (obj, fn) => Object.keys(obj).find(key => fn(obj[key], key, obj));
findKey(
{
barney: { age: 36, active: true },
fred: { age: 40, active: false },
pebbles: { age: 1, active: true }
},
o => o['active']
); // 'barney'复制代码
按照给定的函数条件筛选数组,将最后一个知足条件的元素进行删除。
const findLast = (arr, fn) => arr.filter(fn).pop();
findLast([1, 2, 3, 4], n => n % 2 === 1); // 3复制代码
按照指定数组的深度,将嵌套数组进行展平。
const flatten = (arr, depth = 1) =>
arr.reduce((a, v) => a.concat(depth > 1 && Array.isArray(v) ? flatten(v, depth - 1) : v), []);
flatten([1, [2], 3, 4]); // [1, 2, 3, 4]
flatten([1, [2, [3, [4, 5], 6], 7], 8], 2); // [1, 2, 3, [4, 5], 6, 7, 8]复制代码
按照给定的函数条件,从数组的右边往左依次进行执行。
const forEachRight = (arr, callback) =>
arr
.slice(0)
.reverse()
.forEach(callback);
forEachRight([1, 2, 3, 4], val => console.log(val)); // '4', '3', '2', '1'复制代码
此段代码按照给定的函数条件,支持三个参数做为输入(值、键、对象自己),进行迭代对象。
const forOwn = (obj, fn) => Object.keys(obj).forEach(key => fn(obj[key], key, obj));
forOwn({ foo: 'bar', a: 1 }, v => console.log(v)); // 'bar', 1复制代码
此段代码输出函数的名称。
const functionName = fn => (console.debug(fn.name), fn);
functionName(Math.max); // max (logged in debug channel of console)复制代码
今天的内容就和你们分享到这里,感谢你的阅读,若是你喜欢个人分享,麻烦给个关注、点赞加转发哦,你的支持,就是我分享的动力,后续会持续分享剩余的代码片断,欢迎持续关注。
本文原做者:Fatos Morina
来源网站:medium
注:并不是直译
127个经常使用的JS代码片断,每段代码花30秒就能看懂(一)
127个经常使用的JS代码片断,每段代码花30秒就能看懂(二)
127个经常使用的JS代码片断,每段代码花30秒就能看懂(三)
更多精彩内容,请微信关注“前端达人”公众号!