飞道的博客

127个常用的JS代码片段,每段代码花30秒就能看懂(二)

264人阅读  评论(0)

大家好,在上一篇文章 127个常用的JS代码片段,每段代码花30秒就能看懂(一)里,我分享了前21段代码,今天继续分享21段代码,希望对你的日常工作有所帮助。

22、deepFlatten

通过递归的形式,将多维数组展平成一维数组。


   
  1. const deepFlatten = arr => [].concat(...arr.map(v => ( Array.isArray(v) ? deepFlatten(v) : v)));
  2. deepFlatten([ 1, [ 2], [[ 3], 4], 5]); // [1,2,3,4,5]

23、default

去重对象的属性,如果对象中含有重复的属性,以前面的为准。


   
  1. const defaults = (obj, ...defs) => Object.assign({}, obj, ...defs.reverse(), obj);
  2. defaults({ a: 1 }, { b: 2 }, { b: 6 }, { a: 3 }); // { a: 1, b: 2 }

24、defer

延迟函数的调用,即异步调用函数。


   
  1. const defer = (fn, ...args) => setTimeout(fn, 1, ...args);
  2. defer(console.log, 'a'), console.log( 'b'); // logs 'b' then 'a'

25、degreesToRads

此段代码将标准的度数,转换成弧度。


   
  1. const degreesToRads = deg => (deg * Math.PI) / 180.0;
  2. degreesToRads( 90.0); // ~1.5708

26、difference

此段代码查找两个给定数组的差异,查找出前者数组在后者数组中不存在元素。


   
  1. const difference = (a, b) => {
  2. const s = new Set(b);
  3. return a.filter(x => !s.has(x));
  4. };
  5. difference([ 1, 2, 3], [ 1, 2, 4]); // [3]

27、differenceBy

通过给定的函数来处理需要对比差异的数组,查找出前者数组在后者数组中不存在元素。


   
  1. const differenceBy = (a, b, fn) => {
  2. const s = new Set(b.map(fn));
  3. return a.filter(x => !s.has(fn(x)));
  4. };
  5. differenceBy([ 2.1, 1.2], [ 2.3, 3.4], Math.floor); // [1.2]
  6. differenceBy([{ x: 2 }, { x: 1 }], [{ x: 1 }], v => v.x); // [ { x: 2 } ]

28、differenceWith

此段代码按照给定函数逻辑筛选需要对比差异的数组,查找出前者数组在后者数组中不存在元素。


   
  1. const differenceWith = (arr, val, comp) => arr.filter(a => val.findIndex(b => comp(a, b)) === -1);
  2. differenceWith([ 1, 1.2, 1.5, 3, 0], [ 1.9, 3, 0], (a, b) => Math.round(a) === Math.round(b));
  3. // [1, 1.2]

29、digitize

将输入的数字拆分成单个数字组成的数组。


   
  1. const digitize = n => [...`${n}`].map(i => parseInt(i));
  2. digitize( 431); // [4, 3, 1]

30、distance

计算两点之间的距离


   
  1. const distance = (x0, y0, x1, y1) => Math.hypot(x1 - x0, y1 - y0);
  2. distance( 1, 1, 2, 3); // 2.23606797749979

31、drop

此段代码将给定的数组从左边开始删除 n 个元素


   
  1. const drop = (arr, n = 1) => arr.slice(n);
  2. drop([ 1, 2, 3]); // [2,3]
  3. drop([ 1, 2, 3], 2); // [3]
  4. drop([ 1, 2, 3], 42); // []

32、dropRight

此段代码将给定的数组从右边开始删除 n 个元素


   
  1. const dropRight = (arr, n = 1) => arr.slice( 0, -n);
  2. dropRight([ 1, 2, 3]); // [1,2]
  3. dropRight([ 1, 2, 3], 2); // [1]
  4. dropRight([ 1, 2, 3], 42); // []

33、dropRightWhile

此段代码将给定的数组按照给定的函数条件从右开始删除,直到当前元素满足函数条件为True时,停止删除,并返回数组剩余元素。


   
  1. const dropRightWhile = (arr, func) => {
  2. while (arr.length > 0 && !func(arr[arr.length - 1])) arr = arr.slice( 0, -1);
  3. return arr;
  4. };
  5. dropRightWhile([ 1, 2, 3, 4], n => n < 3); // [1, 2]

34、dropWhile

按照给定的函数条件筛选数组,不满足函数条件的将从数组中移除。


   
  1. const dropWhile = (arr, func) => {
  2. while (arr.length > 0 && !func(arr[ 0])) arr = arr.slice( 1);
  3. return arr;
  4. };
  5. dropWhile([ 1, 2, 3, 4], n => n >= 3); // [3,4]

35、elementContains

接收两个DOM元素对象参数,判断后者是否是前者的子元素。


   
  1. const elementContains = ( parent, child) => parent !== child && parent.contains(child);
  2. elementContains(document.querySelector( 'head'), document.querySelector( 'title')); // true
  3. elementContains(document.querySelector( 'body'), document.querySelector( 'body')); // false

36、filterNonUnique

移除数组中重复的元素


   
  1. const filterNonUnique = arr => [ … new Set(arr)];
  2. filterNonUnique([ 1, 2, 2, 3, 4, 4, 5]); // [1, 2, 3, 4, 5]

37、findKey

按照给定的函数条件,查找第一个满足条件对象的键值。


   
  1. const findKey = (obj, fn) => Object.keys(obj).find(key => fn(obj[key], key, obj));
  2. findKey(
  3. {
  4. barney: { age: 36, active: true },
  5. fred: { age: 40, active: false },
  6. pebbles: { age: 1, active: true }
  7. },
  8. o => o[ 'active']
  9. ); // 'barney'

38、findLast

按照给定的函数条件筛选数组,将最后一个满足条件的元素进行删除。


   
  1. const findLast = (arr, fn) => arr.filter(fn).pop();
  2. findLast([ 1, 2, 3, 4], n => n % 2 === 1); // 3

39、flatten

按照指定数组的深度,将嵌套数组进行展平。


   
  1. const flatten = (arr, depth = 1) =>
  2. arr.reduce((a, v) => a.concat(depth > 1 && Array.isArray(v) ? flatten(v, depth - 1) : v), []);
  3. flatten([ 1, [ 2], 3, 4]); // [1, 2, 3, 4]
  4. flatten([ 1, [ 2, [ 3, [ 4, 5], 6], 7], 8], 2); // [1, 2, 3, [4, 5], 6, 7, 8]

40、forEachRight

按照给定的函数条件,从数组的右边往左依次进行执行。


   
  1. const forEachRight = (arr, callback) =>
  2. arr
  3. .slice( 0)
  4. .reverse()
  5. . forEach(callback);
  6. forEachRight([ 1, 2, 3, 4], val => console.log(val)); // '4', '3', '2', '1'

41、forOwn

此段代码按照给定的函数条件,进行迭代对象。


   
  1. const forOwn = (obj, fn) => Object.keys(obj). forEach(key => fn(obj[key], key, obj));
  2. forOwn({ foo: 'bar', a: 1 }, v => console.log(v)); // 'bar', 1

42、functionName

此段代码输出函数的名称。


   
  1. const functionName = fn => (console.debug(fn.name), fn);
  2. functionName(Math.max); // max (logged in debug channel of console)

小节

今天的内容就和大家分享到这里,感谢你的阅读,如果你喜欢我的分享,麻烦给个关注、点赞加转发哦,你的支持,就是我分享的动力,后续会持续分享剩余的代码片段,欢迎持续关注。

本文原作者:Fatos Morina 来源网站:medium 注:并非直译

长按关注前端达人


转载:https://blog.csdn.net/Ed7zgeE9X/article/details/104284779
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场