zoukankan      html  css  js  c++  java
  • 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(/[a-z]/g, char => char.toUpperCase())

  • 相关阅读:
    vue工程项目中配置测试环境及生产环境线上地址
    复杂表格的拖拉拽,及行列拖拽
    前端骨架屏的资料
    关于vue中的重复key的警告问题
    git 约定规范
    git 博客
    关于svg的一些事
    vue单文件组件2(webpack打包)
    vue单文件组件1(webpack打包)
    vue-resource
  • 原文地址:https://www.cnblogs.com/xzma/p/8482598.html
Copyright © 2011-2022 走看看