每日前端手写题--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, ','));
相关推荐
夜郎king1 小时前
湖南高考天气查询:基于 HTML5 与百度天气 API 实现页面展示
前端·html5·百度天气实践·天气信息可视化
云水一下8 小时前
TypeScript 从零基础到精通(五):高级类型与泛型
前端·javascript·typescript
counterxing8 小时前
vibe coding 之后,我更不想打字了
前端·agent·ai编程
云水一下8 小时前
TypeScript 从零基础到精通(六):类型声明与模块化
javascript·typescript
copyer_xyf8 小时前
Python 模块与包的导入导出
前端·后端·python
研☆香8 小时前
es6新特性功能介绍(四)
前端·ecmascript·es6
微扬嘴角9 小时前
React篇1--JSX语法规则、组件、组件实例的3大特性
前端·react.js·前端框架
copyer_xyf9 小时前
Python venv 虚拟环境
前端·后端·python
橘右今9 小时前
2026 Java后端高频面试宝典
java·开发语言·面试
无聊的老谢9 小时前
Vue 3 + TypeScript 构建大型电信运维平台的前端架构设计
前端·vue.js·typescript