zoukankan      html  css  js  c++  java
  • js 柯里化、深拷贝、浅拷贝

    curry

    const sum = (a, b, c, d) => a + b + c + d
    const curry = fn =>
      (judge = (...args) =>
        args.length >= fn.length ? fn(...args) : (...arg) => judge(...args, ...arg))
    const currySum = curry(sum)
    console.log(currySum(1, 2)(4)(3)) //10
    

    deepClone

    function getType(obj) {
      const str = Reflect.toString.call(obj)
      const map = {
        '[object Boolean]': 'boolean',
        '[object Number]': 'number',
        '[object String]': 'string',
        '[object Function]': 'function',
        '[object Array]': 'array',
        '[object Date]': 'date',
        '[object RegExp]': 'regExp',
        '[object Undefined]': 'undefined',
        '[object Null]': 'null',
        '[object Object]': 'object',
        '[object Map]': 'map',
        '[object Set]': 'set',
      }
      if (obj instanceof Element) {
        // 判断是否是dom元素,如div等
        return 'element'
      }
      return map[str]
    }
    
    function deepClone(ori) {
      const type = getType(ori)
      let copy
      switch (type) {
        case 'array':
          return copyArray(ori, copy)
        case 'object':
          return copyObject(ori, copy)
        case 'function':
          return copyFunction(ori)
        case 'map':
          return copyMap(ori, copy)
        case 'set':
          return copySet(ori, copy)
        default:
          return ori
      }
    }
    
    function copyArray(ori, copy = []) {
      for (const [index, value] of ori.entries()) {
        copy[index] = deepClone(value)
      }
      return copy
    }
    
    function copyObject(ori, copy = {}) {
      for (const [key, value] of Reflect.entries(ori)) {
        copy[key] = deepClone(value)
      }
      return copy
    }
    
    function copyMap(ori, copy = new Map()) {
      for (const [key, value] of ori) {
        copy.set(deepClone(value))
      }
      return copy
    }
    
    function copySet(ori, copy = new Set()) {
      for (const [key, value] of ori.entries()) {
        copy.add(key, deepClone(value))
      }
      return copy
    }
    
    function copyFunction(ori) {
      const fun = eval(ori.toString())
      fun.prototype = ori.prototype
      return fun
    }
    
    

    shallowClone

    function shallowClone(ori) {
      if (typeof ori === 'object' && ori !== null) {
        return Array.isArray(ori) ? copyArray(ori) : copyObject(ori)
      }
      return ori
    }
    function copyObject(ori, copy = {}) {
      for (const [k, v] of Reflect.entries(ori)) {
        copy[k] = v
      }
      return copy
    }
    function copyArray(ori, copy = []) {
      for (const [k, v] of ori.entries()) {
        copy[k] = v
      }
      return copy
    }
    
    
  • 相关阅读:
    Nginx 配置实例-动静分离
    nginx-轮询、权重、ip_hash 、fair模式
    nginx-负载均衡
    nginx 常用的命令和配置文件
    Nginx 的简介
    阿里云--安装nginx AND访问超时
    阿里云-docker安装redis AND(docker基本操作命令)
    阿里云-docker安装mysql
    阅读金字塔原理笔记1
    Springboot-整合redis
  • 原文地址:https://www.cnblogs.com/smzd/p/11912827.html
Copyright © 2011-2022 走看看