// 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(/\b[a-z]/g, char => char.toUpperCase())