本文全面回顾了JavaScript的基础语法和面向对象编程,深入探讨了控制结构、循环、函数、作用域以及DOM操作与事件处理。同时强调了异步编程与Promise的应用,并详细讲解了ES6新特性。针对大厂面试,提供了常见问题解析和面试技巧,旨在帮助开发者提升基础知识和实战能力,成功应对面试挑战。
JavaScript 基本语法回顾变量与数据类型
在JavaScript中,定义变量和使用数据类型是语言的基础。变量用于存储值,而数据类型定义了值的结构和性质。
// 定义变量并赋值
let name = "John Doe";
let age = 30;
// 基本数据类型
let number = 42; // 整型
let string = "Hello, World!"; // 字符串型
let boolean = true; // 布尔型
// 复杂数据类型
let array = [1, 2, 3]; // 数组
let object = {name: "John", age: 30}; // 对象
控制结构与循环
控制结构如if语句允许根据条件执行不同的代码块,而循环结构如for和while用于重复执行操作。
// 条件判断
let markScore = 85;
if (markScore >= 90) {
console.log("优秀");
} else if (markScore >= 75) {
console.log("良好");
} else {
console.log("需努力");
}
// 循环
for (let i = 0; i < 5; i++) {
console.log("循环迭代: " + i);
}
let j = 0;
while (j < 5) {
console.log("循环迭代: " + j);
j++;
}
函数与作用域
函数是组织代码和封装功能的重要工具。作用域决定了变量和函数的可见性。
// 函数定义
function greet(name) {
return `Hello, ${name}`;
}
// 全局作用域
console.log(greet("World")); // 输出 "Hello, World"
// 局部作用域
{
let localVariable = "只在此作用域内可见";
console.log(localVariable); // 输出 "只在此作用域内可见"
}
console.log(localVariable); // 报错:localVariable is not defined
面向对象编程基础
面向对象编程是许多现代JavaScript库和框架的核心。在JavaScript中,通过类与实例实现封装和继承。
class Person {
constructor(name, age) {
this.name = name;
this.age = age;
}
greet() {
console.log(`你好,我叫 ${this.name}`);
}
}
let john = new Person("John", 30);
john.greet(); // 输出 "你好,我叫 John"
class Employee extends Person {
// 继承父类构造函数
constructor(name, age, salary) {
super(name, age);
this.salary = salary;
}
getSalary() {
return this.salary;
}
}
let employee = new Employee("Jane", 25, 5000);
console.log(employee.getSalary()); // 输出 5000
DOM 操作与事件处理
DOM(Document Object Model)允许JavaScript与HTML文档进行交互。事件处理是实现用户交互的关键。
// 获取元素
let button = document.getElementById("myButton");
// 事件监听
button.addEventListener("click", function() {
console.log("按钮被点击了!");
});
// 更新元素内容
document.getElementById("demo").innerHTML = "欢迎使用 JavaScript!";
异步编程与 Promise
处理异步操作时,Promise提供了一种简洁的方式来管理处理函数的顺序。
// Promise 基础
function fetchData() {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve("数据已获取");
}, 2000);
});
}
fetchData().then(data => {
console.log(data); // 输出 "数据已获取"
}).catch(error => {
console.error(error);
});
// async/await
async function fetchAsyncData() {
try {
let data = await fetchData();
console.log(data);
} catch (error) {
console.error(error);
}
}
fetchAsyncData();
ES6 新特性精讲
ES6引入了许多新特性,如箭头函数、let和const、模板字符串等,简化了代码编写和增强了解决问题的能力。
// 箭头函数
let multiply = (x, y) => x * y;
let result = multiply(3, 4);
console.log(result); // 输出 12
// let和const
let firstName = "张三";
const lastName = "李四";
firstName = "王五"; // 报错:Cannot assign to 'firstName' because it is a constant or a read-only property
面试常见问题解析
面试时,面试官经常会提问有关JavaScript的基础知识、面向对象编程、算法、数据结构等。准备面试时,最好熟悉以下几个方面:
- 基础知识:变量类型、作用域、闭包、函数式编程等。
- 面向对象:类、继承、多态、原型链、闭包等。
- 异步编程:回调、Promise、async/await等。
- DOM操作:选择器、事件处理、动画等。
- ES6新特性:箭头函数、模板字符串、let和const等。
- 面试技巧:解释代码、分析复杂问题、设计模式等。
经典实例与实战演练:
- 实例分析:分析常用的算法问题(如排序、查找等),并用JavaScript实现。
- 实战演练:参与编程挑战,如LeetCode、HackerRank上的面试题,以提升实际操作能力。
准备充分、多做练习,加上对基础知识的深入理解,将使你在JavaScript面试中更游刃有余。利用在线资源如慕课网、LeetCode等进行自我学习和实践是一个不错的选择。