每日前端手写题--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, ','));
相关推荐
往事随风灬15 小时前
我被 Volta 的“智能”坑了一下午:pnpm 为何无视项目 Node 版本?
前端·vue.js
xiaofeichaichai15 小时前
Tree Shaking
前端·javascript
lichenyang45316 小时前
给 ArkTS 应用做一个内置的「Network 面板」:实时看清 SSE 每一帧和最后那张卡片
前端
倾颜16 小时前
从手写 Runner 到 LangGraph:受控 Agent 接入 LangGraph
前端·后端·langchain
UXbot16 小时前
AI网页开发工具能替代工具吗?5大平台对比
前端·人工智能·低代码·ui·原型模式·web app
wuhen_n16 小时前
从零到一!前端搭建本地轻量化 RAG 问答系统
前端·langchain·ai编程
落日漫游16 小时前
代码报错难排查?借助Gemini快速修复
前端
niconicoC16 小时前
让 Three.js 场景更真实:我用高斯泼溅和 SparkJS 做了一个可交互的 3D Demo
前端·webgl
Darling噜啦啦16 小时前
JavaScript 数组深度解析:从纯函数到二维数组陷阱,一文吃透前端数据结构核心
前端·javascript·数据结构
万少16 小时前
一封邮件,让我重新打开了搁置半年的鸿蒙应用
前端·javascript·后端