// 1.验证数字 // 使用!isNaN和parseFloat()来检查参数是否是一个数字,使用isFinite()来检查数字是否是有限的。 const validateNumber = n => !isNaN(parseFloat(n)) && isFinite(n) && Number(n) == n // 2.URL参数 // 使用match() 与适当的正则表达式来获得所有键值对,适当的map() 。使用Object.assign()和spread运算符(…)将所有键值对组合到一个对象中,将location.search作为参数传递给当前url。 const getUrlParameters = url => url .match(/([^?=&]+)(=([^&]*))/g) .reduce( (a, v) => ( (a[v.slice(0, v.indexOf('='))] = v.slice(v.indexOf('=') + 1)), a ), {} ) // 3.数组唯一值 // 使用ES6 Set和… rest操作符去掉所有重复值。 const unique = arr => [...new Set(arr)] // 4.列表的tail const tail = arr => (arr.length > 1 ? arr.slice(1) : arr) // 5.交换两个变量的值 // 使用数组解构来交换两个变量之间的值。 // [3, 4] = [4, 3] // 6.数组总和 const sum = arr => arr.reduce((acc, val) => acc + val, 0) // 7.按字符串排序(按字母顺序排列) // 使用split(’‘)分割字符串,sort()使用localeCompare(),使用join(’‘)重新组合。 const sortCharactersInString = str => str .split('') .sort((a, b) => a.localeCompare(b)) .join('') // 8.数组之间的相似性 // 使用filter()移除不是values的一部分值,使用includes()确定。 const similarity = (arr, values) => arr.filter(v => values.includes(v)) // 9.反转一个字符串 // 使用数组解构和Array.reverse()来颠倒字符串中的字符顺序。合并字符以使用join(‘‘)获取字符串。 const reverseString = str => [...str].reverse().join('') // str.split('').reverse().join('') // 10.范围内的随机数 // 使用Math.random()生成一个随机值,使用乘法将其映射到所需的范围 const randomInRange = (min, max) => Math.random() * (max - min) + min // 11.范围内的随机整数 // 使用Math.random()生成一个随机数并将其映射到所需的范围,使用Math.floor()使其成为一个整数 const randomIntegerInRange = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min // 12.其组合成包含所有组合的数组 // 使用reduce()与map()结合来遍历元素,并将其组合成包含所有组合的数组。 const powerset = arr => arr.reduce((a, v) => a.concat(a.map(r => [v].concat(r))), [[]]) // 13.列表的最后 // 返回arr.slice(-1)[0] const last = arr => arr.slice(-1)[0] // 14.用range初始化数组 // 使用Array(end-start)创建所需长度的数组,使用map()来填充范围中的所需值,可以省略start使用默认值0。 const initializeArrayRange = (end, start = 0) => Array.apply(null, Array(end - start)).map((v, i) => i + start) // 15.获取滚动位置 // 如果已定义,请使用pageXOffset和pageYOffset,否则使用scrollLeft和scrollTop,可以省略el来使用window的默认值。 const getScrollPos = (el = window) => ({ x: el.pageXOffset !== undefined ? el.pageXOffset : el.scrollLeft, y: el.pageYOffset !== undefined ? el.pageYOffset : el.scrollTop }) //16.从数组中获取最小值 最大值 const arrayMin = arr => Math.min(...arr) const arrayMax = arr => Math.max(...arr) // 17.扁平化二维数组 // 使用reduce()来获取数组中的所有元素,并使用concat()来使它们flatten。 const flatten = arr => arr.reduce((a, v) => a.concat(v), []) // 18.扁平多维数组 const flatten1 = arr => arr.reduce( (prev, item) => prev.concat(Array.isArray(item) ? flatten1(item) : item), [] ) // 19.过滤数组中的非唯一值 const filterNonUnique = arr => arr.filter(i => arr.indexOf(i) === arr.lastIndexOf(i)); // filterNonUnique([1,2,2,3,4,4,5]) -> [1,3,5] // 20.阶乘 // 使用递归。如果n小于或等于1,则返回1。否则返回n和n – 1的阶乘的乘积。 const factorial = n => n <= 1 ? 1 : n * factorial(n - 1); // 21.偶数或奇数 // 使用Math.abs()将逻辑扩展为负数,使用模(%)运算符进行检查。 如果数字是偶数,则返回true;如果数字是奇数,则返回false。 const isEven = num => num % 2 === 0; //是否偶数 // 22.两点之间的距离 // 使用Math.hypot()计算两点之间的欧几里德距离。 const distance = (x0, y0, x1, y1) => Math.hypot(x1 - x0, y1 - y0); // 23.数组之间的区别 // 从b创建一个Set,然后在a上使用Array.filter(),只保留b中不包含的值。 const difference = (a, b) => { const s = new Set(b); return a.filter(x => !s.has(x)); }; // difference([1,2,3], [1,2]) -> [3] // 24.大写每个单词的首字母 // 使用replace()匹配每个单词的第一个字符,并使用toUpperCase()来将其大写 const capitalizeEveryWord = str => str.replace(/[a-z]/g, char => char.toUpperCase())