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

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
原文地址:https://www.cnblogs.com/webBlog-gqs/p/9628433.html