以下题目来自掘金等其它博客,但是问题的答案都是根据笔者自己的理解做出的。如果你最近想要换工作或者巩固一下自己的前端知识基础,不妨和我一起参与到每日刷题的过程中来,如何?
第15天要刷的手写题如下:
- 实现字符串的repeat方法
- 实现Promise.race方法
- 实现下划线转驼峰命名
下面是我的一些理解:
1. 实现字符串的repeat方法
实现这个功能的途径多种多样,但是要避免在循环中使用accum += str
这种写法,因为这样写性能会很低。
js
function myRepeat (str, count) {
return new Array(count+1).join(str);
}
2. 实现Promise.race方法
- Promise类的静态方法race相比较其他静态方法来说是比较好实现的,原因在于实现这个方法的过程中可以巧妙地使用Promise的状态只能改变一次的特性
- 换个角度理解这个问题,那就是让多个Promise对象ps状态发生改变之后再去改变一个预设的Promise对象x的状态,因为x的状态只能发生一次变化,所以在x的状态发生变化之后其包裹的值就是ps中最先发生状态改变的那一个。
js
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)); // r: 1
3. 实现下划线转驼峰命名
这道题主要是考察replace函数的第二个参数函数,这个参数函数会接受五个形参:匹配到的结果、[组的值、]索引、原始字符串本身
js
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, ','));