每日前端手写题--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, ','));
相关推荐
踩着两条虫17 分钟前
VTJ:快速开始
前端·低代码·架构
木斯佳1 小时前
前端八股文面经大全:携程前端一面(2026-04-17)·面经深度解析
前端·状态模式
2301_799073021 小时前
基于 Next.js + 火山引擎 AI 的电商素材智能生成工具实战——字节跳动前端训练营成果
javascript·人工智能·火山引擎
Java后端的Ai之路1 小时前
LangChain ReAct Agent 核心技术问答
前端·react.js·langchain
码喽7号2 小时前
Vue学习七:MockJs前端数据模拟
前端·vue.js·学习
NotFound4862 小时前
探究分享从对话到执行:OpenTiny NEXT 如何重塑前端智能化开发范式
前端
haina20192 小时前
《品牌观察》专访海纳AI:引领AI面试测评新时代
人工智能·面试·职场和发展
小满zs3 小时前
Next.js精通SEO第二章(robots.txt + sitemap.xml)
前端·seo
kyriewen3 小时前
你的首屏慢得像蜗牛?这6招让页面“秒开”
前端·面试·性能优化