别人遇到的两条前端面试题
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