js常用代码片段

// 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())

 

posted @ 2018-02-28 11:16  吾生有涯,而知无涯!  阅读(224)  评论(0编辑  收藏  举报