2023年7月字节前端青训营入营题目记录(大题)

前言:

不一定是完整的题目内容,但意思差不多是一个意思

1.实现一个url解析成对象的函数:

javascript 复制代码
 function ParseParams(url: string): Record<string, any> {
    const paramsstr = url.split("?")[1];
    const paramsArr = paramsstr.split("&");
    let paramsobj: Record<string, any> = {};
    paramsArr.forEach((item) => {
      if (/=/.test(item)) {
        //处理有值的参数
        let [key, val]: [string, any] = item.split("=") as [string, any]; //分割key和value;
        val = decodeURIComponent(val); //中文解码;
        val = /^\d+$/.test(val) ? parseInt(val) : val; //是否需要转化成数字
        if (paramsobj.hasOwnProperty(key)) {
          //看看是否有这个,如果已经有了,则创建一个数组,添加进去
          paramsobj[key] = [].concat(paramsobj[key], val);
        } else {
          paramsobj[key] = val;
        }
      } else {
        paramsobj[item] = true;
      }
    });
    return paramsobj;
  }

这个题差不多是这个意思,就是url后面的param,转成对象的形式,值得注意的是需要考虑一下特殊情况比如:

  • null和undenfind
  • 参数中"=","&"等特殊字符的情况
  • key多次出现,转成数组的情况

但是上面的代码测试没过全,还需要大神的指点

1.实现一个PromiseLimit函数:

题目需要满足以下要求

1.实现 PromiseLimit函数;

  1. PromiseLimit 函数接受一个整数 limit, 表示最大并发数;

  2. PromiseLimit可以通过 enqueue 方法添加任务, 该方法接

受一个返回Promise 的函数, 4.将其加入到任务队列中并返

回一个新的 Promise 对象, 用于获取任务的结果;

4.当任务队列中有空闲位置时, 该任务将被立即执行; 否则,该任务将被添加到等待队列中, 等待其他任务完成后再执行;

5.当任务执行完成时, 无论成功或失败, 都应该将其从任务队列中移除并执行下一个任务:

enqueue 方法返回的 Pronise对象应该能够获取任务的执行结果;

6.支持 Promise. all 等待所有任务完成,并获取它们的结果;

7.可以处理任务执行出错的情况。

GPT4真强大

相关推荐
程序员Agions3 分钟前
程序员武学修炼手册(二):进阶篇——小有所成,从能跑就行到知其所以然
前端·程序员
小画家~7 分钟前
第四十六: channel 高级使用
java·前端·数据库
小贵子的博客17 分钟前
Ant Design Vue <a-table>
前端·javascript·vue.js·anti-design-vue
m0_5027249519 分钟前
vue动态设置背景图片后显示异常
前端·css
console.log('npc')27 分钟前
vue2中子组件父组件的修改参数
开发语言·前端·javascript
奋斗吧程序媛1 小时前
vue3 Study(1)
前端·javascript·vue.js
@Autowire1 小时前
Layout-position
前端·css
QQ12958455041 小时前
ThingsBoard - APP首页修改为手工选择组织
前端·javascript·物联网·iot
whyfail1 小时前
前端数据存储新选择:IndexedDB与Dexie.js技术指南
前端·javascript·数据库
椰果uu1 小时前
vue-virtual-scroller-虚拟滚动列表:渲染不定高度长列表+可控跳转
前端·javascript·typescript·vue