前端面试三之控制语句

1.for-in

for...in 是 JavaScript 中用于遍历对象可枚举属性的循环语句。它主要用于遍历对象的属性名(键),而不是属性值。

(1)遍历对象属性

javascript 复制代码
const person = {
  name: 'Alice',
  age: 25,
  job: 'Developer'
};

for (const key in person) {
  console.log(`${key}: ${person[key]}`);
}
// 输出:
// name: Alice
// age: 25
// job: Developer

2.for-of

for...of 是 ES6 (ECMAScript 2015) 引入的循环语句,用于遍历可迭代对象 (如数组、字符串、Map、Set 等)的元素值。for...of 是现代 JavaScript 中遍历集合数据的首选方式,提供了更简洁、更直观的语法,特别适合处理数组和其他可迭代对象。

(1)遍历数组

javascript 复制代码
const fruits = ['apple', 'banana', 'orange'];

for (const fruit of fruits) {
  console.log(fruit);
}
// 输出:
// apple
// banana
// orange

(2)遍历字符串

javascript 复制代码
const str = 'hello';

for (const char of str) {
  console.log(char);
}
// 输出:
// h
// e
// l
// l
// o

(3)结合解构赋值

javascript 复制代码
const users = [
  { name: 'Alice', age: 25 },
  { name: 'Bob', age: 30 }
];

for (const { name, age } of users) {
  console.log(`${name} is ${age} years old`);
}

(4)与 for...in 的区别

特性 for...of for...in
用途 遍历可迭代对象的值 遍历对象属性名
获取内容 属性值 属性名(键)
原型链属性 不涉及原型链 会遍历继承的可枚举属性
数组使用 只遍历数字索引元素 遍历所有可枚举属性(包括非数字键)
适用对象 可迭代对象(Array, Map, Set等) 任意对象

3.try-catch

try-catch 是 JavaScript 中处理运行时错误的异常处理机制,允许你"尝试"执行可能出错的代码,并"捕获"处理可能发生的异常,防止程序意外终止。

javascript 复制代码
try {
  // 可能抛出错误的代码
} catch (error) {
  // 错误处理代码
} finally {
  // 无论是否出错都会执行的代码
}

(1)基本错误捕获

javascript 复制代码
try {
  console.log(notDefined); // 引用未定义变量
} catch (error) {
  console.error('发生错误:', error.message);
  // 输出: "发生错误: notDefined is not defined"
}

(2)使用 finally

javascript 复制代码
let file = openFile();
try {
  processFile(file);
} catch (error) {
  console.error('文件处理失败:', error);
} finally {
  closeFile(file); // 确保文件总是被关闭
}
相关推荐
极梦网络无忧22 分钟前
基于 Vite + Vue3 的组件自动注册功能
前端·javascript·vue.js
Predestination王瀞潞35 分钟前
5.4.3 通信->WWW万维网内容访问标准(W3C):WWW(World Wide Web) 协议架构(分层)
前端·网络·网络协议·架构·www
爱学习的程序媛1 小时前
【Web前端】优化Core Web Vitals提升用户体验
前端·ui·web·ux·用户体验
zabr1 小时前
花了 100+ 篇笔记,我整理出 了一套 AI Agent 工程完全指南
前端·后端·agent
软弹1 小时前
深入理解 React Ref 机制:useRef 与 forwardRef 的协作原理
前端·javascript·react.js
YaHuiLiang1 小时前
Ai Coding浪潮下的前端:“AI在左,裁员在右”
前端
雪碧聊技术1 小时前
前端vue代码架子搭建
前端·javascript·vue.js·前端项目代码框架搭建
爱学习的程序媛1 小时前
【Web前端】前端用户体验优化全攻略
前端·ui·交互·web·ux·用户体验
han_1 小时前
JavaScript设计模式(二):策略模式实现与应用
前端·javascript·设计模式
x***r1511 小时前
Notepad++ 8.6 安装教程:详细步骤+自定义安装路径(附注意事项)
linux·前端·javascript