JavaScript 是一种基于原型的面向对象的语言。对象是 JavaScript 中最核心的数据类型,它们允许程序者以结构化的方式组织和操作数据。在 JavaScript 中,每个对象都包含了一组属性和方法,可以用于存储和操作数据。
基础语法
let person = {};
let person = {
firstName: 'John',
lastName: 'Doe',
age: 30
};
console.log(person.firstName); // 输出 'John'
对象字面量与构造函数
JavaScript 提供了两种创建对象的常见方式:对象字面量和构造函数。
对象字面量
let person = {
firstName: 'John',
lastName: 'Doe',
age: 30
};
构造函数
function Person(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
let person = new Person('John', 'Doe');
对象方法
function Person(firstName, lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
let person = new Person('John', 'Doe');
console.log(person.firstName); // 输出 'John'
JavaScript对象核心操作
访问与修改属性
let person = {
firstName: 'John',
lastName: 'Doe',
age: 30
};
person.age = 31; // 修改 age 属性
console.log(person.age); // 输出 "31"
嵌套对象与数组
JavaScript 对象可以包含嵌套的对象和数组,这使得数据结构可以复杂到包含多层层级。
let person = {
firstName: 'John',
lastName: 'Doe',
age: 30,
addresses: [
{ city: 'New York', country: 'USA' },
{ city: 'Los Angeles', country: 'USA' }
]
};
console.log(person.addresses[0].city); // 输出 "New York"
方法链式调用
JavaScript 中的方法可以进行链式调用,即可以在一行代码中调用多个方法,以实现高效的代码编写。
console.log(person.greet()); // 输出 "Hello, my name is John Doe."
访问对象属性的快捷方式
使用点符号 .
或者方括号 []
访问对象属性是常见的操作。
console.log(person['firstName']); // 输出 "John"
构造函数与原型链
构造函数与实例化
JavaScript 的构造函数用于创建具有特定属性和方法的新对象实例。
function Person(name) {
this.name = name;
}
let john = new Person('John');
console.log(john.name); // 输出 "John"
原型链
JavaScript 中的对象具有原型链,每个对象都可以通过原型链访问到构造函数原型上的方法和属性。
function Person(name) {
this.name = name;
}
Person.prototype.greet = function() {
return `Hello, my name is ${this.name}.`;
};
let john = new Person('John');
console.log(john.greet()); // 输出 "Hello, my name is John."
使用 __proto__
访问原型
JavaScript 的 __proto__
属性可以用于直接访问对象的原型。
let john = {
name: 'John'
};
john.__proto__.greet = function() {
return `Hello, my name is ${this.name}.`;
};
console.log(john.greet()); // 输出 "Hello, my name is John."
ES6新特性 - 类与ES7新特性 - 解构赋值
ES6类
ES6 引入了类作为另一种创建对象的方式。
class Person {
constructor(name) {
this.name = name;
}
greet() {
return `Hello, my name is ${this.name}.`;
}
}
let john = new Person('John');
console.log(john.greet()); // 输出 "Hello, my name is John."
ES7解构赋值
ES7 解构赋值进一步简化了对象的提取和合并。
let { firstName, lastName } = person;
console.log(firstName); // 输出 "John"
console.log(lastName); // 输出 "Doe"
实战案例与代码示例
用户管理器
构建一个简单用户管理器,用于跟踪用户信息和管理用户的登录状态。
class UserManager {
constructor() {
this.users = [];
}
createUser(username, password) {
this.users.push({ username, password });
}
loginUser(username, password) {
return this.users.find(user => user.username === username && user.password === password);
}
}
let userManager = new UserManager();
userManager.createUser('john', 'password123');
userManager.createUser('jane', 'password321');
console.log(userManager.loginUser('john', 'password123')); // 输出 { username: 'john', password: 'password123' }
console.log(userManager.loginUser('jane', 'password321')); // 输出 { username: 'jane', password: 'password321' }
课程信息收集器
开发一个课程信息收集器,用于收集并管理课程的详细信息。
class Course {
constructor(courseId, title, description) {
this.courseId = courseId;
this.title = title;
this.description = description;
}
}
class CourseManager {
constructor() {
this.courses = [];
}
addCourse(course) {
this.courses.push(course);
}
getCourses() {
return this.courses;
}
}
let courseManager = new CourseManager();
let mathCourse = new Course('MATH101', 'Calculus I', 'Introduction to differential calculus.');
let physicsCourse = new Course('PHYS101', 'Fundamentals of Physics', 'A comprehensive introduction to classical physics.');
courseManager.addCourse(mathCourse);
courseManager.addCourse(physicsCourse);
console.log(courseManager.getCourses()); // 输出 [{...mathCourse}, {...physicsCourse}]
通过以上的JavaScript对象资料,您已经掌握了许多关键概念和技巧,从基础操作到进阶应用。不断实践和应用这些知识,将使您在编程道路上更进一步。