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

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

韩小韩
2021-06-18 / 0 评论 / 261 阅读 / 正在检测是否收录...
温馨提示:
本文最后更新于2021年06月18日,已超过1090天没有更新,若内容或图片失效,请留言反馈。

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);

题干

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))

题干

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]

题干

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

最后

0

评论 (0)

取消