每日前端手写题--day15

以下题目来自掘金等其它博客,但是问题的答案都是根据笔者自己的理解做出的。如果你最近想要换工作或者巩固一下自己的前端知识基础,不妨和我一起参与到每日刷题的过程中来,如何?

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

  1. 实现字符串的repeat方法
  2. 实现Promise.race方法
  3. 实现下划线转驼峰命名

下面是我的一些理解:

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, ','));
相关推荐
kyriewen8 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒8 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马9 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮9 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦9 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer9 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队9 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY9 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
她的男孩9 小时前
后台接口加密别只会 HTTPS,ForgeAdmin 的 RSA + SM4/AES 源码拆解
后端·面试·开源
远航_10 小时前
OpenSpec 完整详细介绍
前端·后端