JavaScript面试必杀技:电话号码格式化从入门到精通

第一层:发现问题

面试官追问 :"如果需求变更为国际号码格式 +1 123-456-7890,你要修改多少处代码?"

小瓜顿时语塞,意识到问题:

  1. 硬编码陷阱:涉及7处索引修改
  2. 魔法数字:3/3/4分段规则没有明确表达
  3. 维护噩梦:格式与代码高度耦合

第二层:初级优化

小瓜改进:"可以用模板字符串提升可读性!"

javascript 复制代码
// 解法二:模板字符串法
function getPhoneNumber(arr) {
  return `(${arr[0]}${arr[1]}${arr[2]}) ${arr[3]}${arr[4]}${arr[5]}-${arr[6]}${arr[7]}${arr[8]}${arr[9]}`;
}
改进点 优势 遗留问题
消除+拼接 代码更简洁 索引仍然硬编码
直观展示格式 结构一目了然 分段规则未抽象

第三层:中级优化

面试官提示:"如果格式需要动态调整呢?"

javascript 复制代码
// 解法三:模板替换法
function getPhoneNumber(arr) {
  let format = '(xxx) xxx-xxxx';
  arr.forEach(num => {
    format = format.replace('x', num);
  });
  return format;
}

技术亮点

  • 格式与逻辑分离
  • 支持动态模板(如xx-xxxx-xxxx
  • 代码自解释性强

第四层:高级优化

面试官追问:"如何处理非数字输入?"

javascript 复制代码
// 解法四:防御性编程版
function getPhoneNumber(arr) {
  // 输入校验
  if (!Array.isArray(arr)) throw new TypeError("需要数组输入");
  const digits = arr.map(n => {
    const num = Number(n);
    if (isNaN(num)) throw new Error("包含非数字");
    return num % 10; // 确保0-9
  });
  
  // 格式抽象
  const segments = [3, 3, 4];
  let phone = '';
  let index = 0;
  
  segments.forEach((length, i) => {
    phone += (i === 0) ? '(' : (i === 1) ? ') ' : '-';
    phone += digits.slice(index, index + length).join('');
    index += length;
  });
  
  return phone;
}

面试考点全景图

  1. 基础能力

    • 数组操作(slice/indexOf)
    • 字符串拼接(+/模板字符串)
  2. 代码质量

    • 避免硬编码
    • 关注可维护性
  3. 工程思维

    • 防御性编程
    • 需求变更应对
  4. 性能意识

    • 时间复杂度分析
    • 内存管理

终极建议

  1. 新手必做:先写出能跑的代码
  2. 进阶要求:添加输入校验
  3. 高手标配:支持格式配置化
  4. 专家境界:提供单元测试套件
javascript 复制代码
// 测试用例
test('基础功能', () => {
  expect(getPhoneNumber([1,2,3,4,5,6,7,8,9,0]))
    .toBe('(123) 456-7890');
});

test('异常输入', () => {
  expect(() => getPhoneNumber([1,2,3])).toThrow();
});

通过这道经典面试题,我们看到的不仅是代码的演进,更是工程师思维的成长轨迹。记住:代码质量决定职业高度,防御性编程体现工程素养。下次面试时,希望你能用这四层解法惊艳面试官!

相关推荐
2301_8012522219 小时前
Vue中的指令
前端·javascript·vue.js
烛阴19 小时前
彻底搞懂Lua闭包
前端·lua
天***889619 小时前
Chrome扩展安装插件教程,Edge安装插件扩展教程,浏览器安装扩展程序方法
前端·chrome·edge
心.c20 小时前
深拷贝浅拷贝
开发语言·前端·javascript·ecmascript
IT_陈寒20 小时前
Vue 3.4性能优化实战:5个鲜为人知的Composition API技巧让打包体积减少40%
前端·人工智能·后端
前端九哥20 小时前
💻【急招!27届前端实习生】广州4399实习太幸福了!江景+三餐+健身房全都有😭
前端·面试·招聘
咖啡の猫20 小时前
Vue全局事件总线
前端·javascript·vue.js
大厂码农老A20 小时前
我带的外包兄弟放弃大厂转正,薪资翻倍入职字节
java·后端·面试
Lovereo21 小时前
我的目标检测性能优化之路:预算不够、GPU 没有、但性能我得要
前端
T___T21 小时前
JavaScript 变量声明详解:var、let、const 的核心差异
javascript·面试