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();
});

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

相关推荐
子兮曰1 小时前
async/await高级模式:async迭代器、错误边界与并发控制
前端·javascript·github
恋猫de小郭1 小时前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
GIS之路3 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒4 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
Kagol5 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉5 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau5 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生6 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼6 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范
明君879976 小时前
Flutter 如何给图片添加多行文字水印
前端·flutter