刷刷题16

如何优化以下代码的执行效率?

javascript 复制代码
const data = Array(1e5).fill({ value: Math.random() });

function process() {
  return data.map(item => ({
    ...item,
    score: item.value * 100
  }));
}

答案

ini 复制代码
// 优化方案:避免展开操作符和频繁对象创建
function optimizedProcess() {
  const result = new Array(data.length);
  for (let i = 0; i < data.length; i++) {
    const item = data[i];
    result[i] = { 
      value: item.value, 
      score: item.value * 100 
    };
  }
  return result;
}

如何设计一个支持 Tree-shaking 的 JavaScript 工具库?

  1. 代码规范

    • 使用 ES Modules 语法(import/export
    • 避免副作用(如全局变量修改)
  2. 构建配置

arduino 复制代码
// rollup.config.js
export default {
  input: 'src/index.js',
  output: {
    file: 'dist/bundle.esm.js',
    format: 'esm' // 输出 ESM 格式
  },
  treeshake: {
    moduleSideEffects: false
  }
};
  1. 实践验证

    • 使用 webpack-bundle-analyzer 分析产物
    • 确保未使用代码被正确剔除

如何实现前端错误监控的"全栈可追溯"?

javascript 复制代码
window.addEventListener('error', (event) => {
  const log = {
    message: event.message,
    stack: event.error?.stack,
    component: getCurrentComponent(), // 通过 Context API 获取
    user: getUserID(),
    env: navigator.userAgent
  };
  sendToServer(log); // 使用 Beacon API 发送
});

// Promise 错误捕获
window.addEventListener('unhandledrejection', (e) => {
  e.preventDefault();
  logError(e.reason);
});

全栈链路

复制代码
前端埋点 → 分布式日志收集(Kafka) → 存储(Elasticsearch) → 可视化(Grafana)

实现一个支持最大并发数 的 Promise 调度器 Scheduler,要求最多同时执行 2 个任务。

答案

kotlin 复制代码
class Scheduler {
  constructor(limit = 2) {
    this.queue = [];
    this.running = 0;
    this.limit = limit;
  }

  add(promiseFn) {
    return new Promise((resolve) => {
      const execute = () => {
        this.running++;
        promiseFn().then(resolve).finally(() => {
          this.running--;
          this.next();
        });
      };

      if (this.running < this.limit) {
        execute();
      } else {
        this.queue.push(execute);
      }
    });
  }

  next() {
    if (this.queue.length && this.running < this.limit) {
      this.queue.shift()();
    }
  }
}

测试用例

scss 复制代码
const scheduler = new Scheduler(2);
const delay = (time) => () => new Promise(r => setTimeout(r, time));

scheduler.add(() => delay(1000)()).then(() => console.log(1));
scheduler.add(() => delay(500)()).then(() => console.log(2));
scheduler.add(() => delay(300)()).then(() => console.log(3));
// 输出顺序:2 → 3 → 1(任务1和2先执行,任务3在任务2完成后执行)
相关推荐
文心快码BaiduComate7 分钟前
WAVE SUMMIT深度学习开发者大会2025举行 文心大模型X1.1发布
前端·后端·程序员
babytiger7 分钟前
python 通过selenium调用chrome浏览器
前端·chrome
passer98114 分钟前
基于webpack的场景解决
前端·webpack
华科云商xiao徐20 分钟前
Java并发编程常见“坑”与填坑指南
javascript·数据库·爬虫
知其然亦知其所以然23 分钟前
面试官微笑发问:第100万页怎么查?我差点当场沉默…
后端·mysql·面试
奶昔不会射手27 分钟前
css3之grid布局
前端·css·css3
举个栗子dhy31 分钟前
解决在父元素上同时使用 onMouseEnter和 onMouseLeave时导致下拉菜单无法正常展开或者提前收起问题
前端·javascript·react.js
Coding_Doggy37 分钟前
苍穹外卖前端Day1 | vue基础、Axios、路由vue-router、状态管理vuex、TypeScript
前端