• 别人遇到的两条前端面试题


    9.写出一个数组展开函数, 如输入: [1,[2,[3,4,2],2],5,[6]], 输出数组: [1,2,3,4,2,2,5,6]

    function traversal(arr, result){
      for (var i=0;i<arr.length;i++) {
        if (isArr(arr[i])) {
          traversal(arr[i], result)
        } else {
          result.push(arr[i])
        }
      }
    }
    function isArr (arr) {
      if (Object.prototype.toString.call(arr) === '[object Array]') return true
      return false
    }
    function arrfn (list) {
      if (!isArr(list)) return
      var result = []
      traversal(list, result)
      return result
    }
    console.log(arrfn([1,[2,[3,4,2],2],5,[6]]))   // [1, 2, 3, 4, 2, 2, 5, 6]

    10. 请实现一个querystring的序列化函数,stringify() 

    例如: stringify({a:1, b:2})

    输出: a=1&b=2

    (输入对象可能包含嵌套对象)

    function isObj (obj) {
      if (Object.prototype.toString.call(obj) === '[object Object]') return true
    return false
    } function resolveObj (obj, arr) { for (var i in obj) { if (isObj(obj[i])) { resolveObj(obj[i], arr) } else { arr.push(i+'='+obj[i]) } } } function stringify (obj) { if (!isObj(obj)) return var arr = [] resolveObj(obj, arr) return arr.join('&') } console.log(stringify({a:1, b:2, c: {d:3, e: {f: 4}}})) // a=1&b=2&d=3&f=4
  • 相关阅读:
    011-通过网络协议解析网络请求-DNS-ARP-TCPIP
    010-HTTP协议
    009-DNS域名解析系统
    008-ICMP协议(网络控制文协议)
    007-IP报文协议
    007-排序算法-堆排序
    006-排序算法-希尔排序
    007-Linux 查看端口
    005-排序算法-归并排序
    004-排序算法-选择排序
  • 原文地址:https://www.cnblogs.com/webBlog-gqs/p/9628433.html
Copyright © 2020-2023  润新知