每日前端手写题--day15

如果你最近想要换工作或者巩固一下自己的前端知识基础,不妨和我一起参与到每日刷题的过程中来,如何?

第15天要刷的手写题如下:

  1. 实现字符串的repeat方法

  2. 实现Promise.race方法

  3. 实现下划线转驼峰命名

下面是我的一些理解:

1. 实现字符串的repeat方法

实现这个功能的途径多种多样,但是要避免在循环中使用accum += str这种写法,因为这样写性能会很低。

function myRepeat (str, count) {
    return new Array(count+1).join(str);
}

2. 实现Promise.race方法

  • Promise类的静态方法race相比较其他静态方法来说是比较好实现的,原因在于实现这个方法的过程中可以巧妙地使用Promise的状态只能改变一次的特性

  • 换个角度理解这个问题,那就是让多个Promise对象ps状态发生改变之后再去改变一个预设的Promise对象x的状态,因为x的状态只能发生一次变化,所以在x的状态发生变化之后其包裹的值就是ps中最先发生状态改变的那一个。

function race (ps) {
    return new Promise ((res, rev) => {
        ps.forEach(
            p => {
                p.then(res,rev)
            }
        )
    })
}


function generatePs (gap) {
    return new Promise(res=>{
        setTimeout(()=>{
            console.log('gap: ', gap);
            res(gap);
        }, gap * 1000)
    })
}

const ps = [1,2,3,4,5].map(v=>generatePs(v));

const r = race(ps).then(d=>void console.log('r:', d)); 

3. 实现下划线转驼峰命名

这道题主要是考察replace函数的第二个参数函数,这个参数函数会接受五个形参:匹配到的结果、[组的值、]索引、原始字符串本身

function toCamelCase (str) {
    return str.replace(
        /_[a-zA-Z]/g, function (match, index, origin) {
            return index === 0 ? match[1] : match[1].toUpperCase(); 
        }
    )
}


function toCamelCasePlus (str, token) {
    return str.replace(
        new RegExp(`${token}[a-zA-Z]`, "g"), function (match, index, origin) {
            return index === 0 ? match[1] : match[1].toUpperCase(); 
        }
    )
}

const _str = "d,g,sad,2sd,g";

console.log(toCamelCasePlus(_str, ','));

最后

如果你现在正在找工作,可以私信“web”进群领取前端面试小册以及更多阿里、字节大厂面试真题合集,和p8大佬一起交流。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Web面试那些事儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值