前端算法总结

深拷贝

var deepCopy = function(obj) {
        console.log(11)
        if (typeof obj !== 'object') return;
        var newObj = obj instanceof Array ? [] : {};
        for (var key in obj) {
            if (obj.hasOwnProperty(key)) {
                newObj[key] = typeof obj[key] === 'object' ? deepCopy(obj[key]) : obj[key];
            }
        }
        return newObj;
      }

扁平化

const flatten = (arr) => {
        let result = [];
        arr.forEach((item, i, arr) => {
          // 若为数组,递归调用 faltten,并将结果与result合并
          if (Array.isArray(item)) {
            result = result.concat(flatten(item));
          } else {
            result.push(arr[i])
          }
        })
        return result;
      };

扁平化es6

function flatten(arr) {
    while (arr.some(item => Array.isArray(item))) {
        arr = [].concat(...arr);
    }
    return arr;
}

楼梯

function climbStairs(n) {
  if (n == 1) return 1
  if (n == 2) return 2
  return climbStairs(n-1) + climbStairs(n-2)
}

复合函数

function pipe() {
    var fns = [].slice.call(arguments) //能将具有length属性的对象转成数组
    return function (initialAgr) {
        var res = initialAgr
        for (var i = 0; i < fns.length; i++) {
            res = fns[i](res)
        }
        return res
    }
}

数据类型判断

function typeOf(obj) {
    return Object.prototype.toString.call(obj).slice(8, -1).toLowerCase()
}
typeOf(new Date)

Function 与 eval 有相同的字符串参数特性

var json = '{"name":"小姐姐", "age":20}';
var obj = (new Function('return ' + json))();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值