Joe博客 老板每日分享面试题,羞辱我这个前端小白,请看题!
题干
1 2 3 4 5 6
| let a = { b: 123, c: "456", e: "789", }; let str = "a{a.b}aa{a.c}aa {a.d}aaaa";
|
1 2 3 4 5 6 7 8 9 10
| str .match(/{\w\.\w}/g) .forEach( (itm) => (str = str.replace( itm, a[itm.match(/\.\w/g)[0].replace(/./, "")] || itm, )), ); console.log(str);
|
Joe大佬解题方案
1 2 3 4 5 6 7
| str = str.replace(/{\w\.\w}/g, ($1) => { const { groups: { key }, } = /{\w\.(?<key>\w)}/.exec($1); return a[key] || $1; }); console.log(str);
|
此题可看出,Joe大佬的代码运用了JS高级,博主只能勉强解出,这就是差距。
题干
1
| const arr = [1, [2, 3, [4, [5]]], 6];
|
- 本题要求: 把 arr 数组 扁平化处理
- 本题结果: [1,2,3,4,5,6]
博主解题方案
1 2 3 4 5 6 7 8
| let newArr = []; hanJoe(arrs); function hanJoe(arrs) { arrs.forEach((itm) => itm instanceof Array ? hanJoe(itm) : newArr.push(itm), ); } console.log(newArr);
|
Joe大佬解题方案
1 2 3 4 5 6 7
| const flat = (arr) => arr.reduce( (prev, curr) => Array.isArray(curr) ? [...prev, ...flat(curr)] : [...prev, curr], [], ); console.log(flat(arr));
|
此题可看出,Joe大佬再次运用了JS高级,博主的解题方案平平无奇,这就是差距。
题干
1 2 3 4 5 6 7 8 9 10 11
| function isOdd(num) { return num % 2 == 1; } function isEven(num) { return num % 2 == 0; } function isSane(num) { return isEven(num) || isOdd(num); } var values = [7, 4, "13", -9, Infinity]; var r = values.map(isSane);
|
- 本题要求: 脑子里运算,并输出 r
- 本题结果: [true,true,true,false,false]
这题给我普及了 Array.map() ,博主不会map
题干
1
| let res = "b" + "a" + +"a" + "a";
|
- 本题要求: 脑子里运算,并输出 res
- 本题结果: baNaNa
最后