刷刷题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完成后执行)
相关推荐
码农黛兮_4628 分钟前
CSS3 基础知识、原理及与CSS的区别
前端·css·css3
水银嘻嘻1 小时前
web 自动化之 Unittest 四大组件
运维·前端·自动化
(((φ(◎ロ◎;)φ)))牵丝戏安1 小时前
根据输入的数据渲染柱形图
前端·css·css3·js
wuyijysx1 小时前
JavaScript grammar
前端·javascript
溪饱鱼1 小时前
第6章: SEO与交互指标
服务器·前端·microsoft
咔_2 小时前
LinkedList详解(源码分析)
前端
逍遥德2 小时前
CSS可以继承的样式汇总
前端·css·ui
读心悦2 小时前
CSS3 选择器完全指南:从基础到高级的元素定位技术
前端·css·css3
学渣y3 小时前
React状态管理-对state进行保留和重置
javascript·react.js·ecmascript
_龙衣3 小时前
将 swagger 接口导入 apifox 查看及调试
前端·javascript·css·vue.js·css3