Home

前端正则,递归面试题 - Joe老板出题

Joe博客 老板每日分享面试题,羞辱我这个前端小白,请看题!

第一题 正则替换

题干

let a = {
  b: 123,
  c: "456",
  e: "789",
};
let str = "a{a.b}aa{a.c}aa {a.d}aaaa";
  • 本题要求: 把 str 字符串中 { a.b } 这种 替换成 a对象中对应的值

  • 本题结果: a123aa456aa {a.d}aaaa

    博主解题方案

str
  .match(/{\w\.\w}/g)
  .forEach(
    (itm) =>
      (str = str.replace(
        itm,
        a[itm.match(/\.\w/g)[0].replace(/./, "")] || itm,
      )),
  );
console.log(str);

Joe大佬解题方案

str = str.replace(/{\w\.\w}/g, ($1) => {
  const {
    groups: { key },
  } = /{\w\.(?<key>\w)}/.exec($1);
  return a[key] || $1;
});
console.log(str);

此题可看出,Joe大佬的代码运用了JS高级,博主只能勉强解出,这就是差距。

第二题 数组扁平化

题干

const arr = [1, [2, 3, [4, [5]]], 6];
  • 本题要求: 把 arr 数组 扁平化处理
  • 本题结果: [1,2,3,4,5,6] 博主解题方案
let newArr = [];
hanJoe(arrs);
function hanJoe(arrs) {
  arrs.forEach((itm) =>
    itm instanceof Array ? hanJoe(itm) : newArr.push(itm),
  );
}
console.log(newArr);

Joe大佬解题方案

const flat = (arr) =>
  arr.reduce(
    (prev, curr) =>
      Array.isArray(curr) ? [...prev, ...flat(curr)] : [...prev, curr],
    [],
  );
console.log(flat(arr));

此题可看出,Joe大佬再次运用了JS高级,博主的解题方案平平无奇,这就是差距。

第三题 也不知道怎么命名

题干

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

第四题 运算

题干

let res = "b" + "a" + +"a" + "a";
  • 本题要求: 脑子里运算,并输出 res
  • 本题结果: baNaNa

最后

快来插个眼吧!