JS权威指南读书笔记
    		       		warning:
    		            这篇文章距离上次修改已过439天,其中的内容可能已经有所变动。
    		        
        		                
                在JavaScript中,有一些特殊的对象,被称为内置对象,它们提供了一些常用的、已经定义好的功能。例如,Math对象就是一个内置对象,它提供了一系列的数学常量和函数。
- 创建一个新的对象
在JavaScript中,创建一个新的对象可以使用以下几种方法:
- 使用对象字面量:
var person = {
    firstName: "John",
    lastName: "Doe",
    age: 50,
    eyeColor: "blue"
};- 使用构造函数:
function Person(firstName, lastName, age, eyeColor) {
    this.firstName = firstName;
    this.lastName = lastName;
    this.age = age;
    this.eyeColor = eyeColor;
}
 
var myFather = new Person("John", "Doe", 50, "blue");- 使用class(ES6+):
class Person {
    constructor(firstName, lastName, age, eyeColor) {
        this.firstName = firstName;
        this.lastName = lastName;
        this.age = age;
        this.eyeColor = eyeColor;
    }
}
 
const myMother = new Person("Jane", "Doe", 48, "green");- 访问对象的属性和方法
在JavaScript中,访问对象的属性和方法可以使用以下几种方式:
- 使用点符号:
console.log(person.firstName); // 输出:John- 使用方括号:
console.log(person["firstName"]); // 输出:John- 访问对象方法:
console.log(person.toString()); // 输出:[object Object]- 枚举对象的属性和方法
在JavaScript中,可以使用for-in循环来枚举对象的属性和方法:
for (let key in person) {
    if (person.hasOwnProperty(key)) {
        console.log(key + ": " + person[key]);
    }
}- 删除对象的属性和方法
在JavaScript中,可以使用delete运算符来删除对象的属性和方法:
delete person.age; // 删除person对象的age属性- 检查对象的属性和方法是否存在
在JavaScript中,可以使用in运算符来检查对象是否拥有某个属性,或者是否可以访问某个属性:
console.log("age" in person); // 输出:true- 创建动态的对象
在JavaScript中,可以使用Object.defineProperty()方法来创建动态的对象属性:
let person = {};
 
Object.defineProperty(person, "fullName", {
    get: function() {
        return this.firstName + " " + this.lastName;
    },
    set: function(value) {
        let names = value.split(" ");
        this.firstName = names[0];
        this.lastName = names[names.length - 1];
    }
});
 
person.fullName = "Jane Doe";
console.log(person.fullName); // 输出:Jane Doe- 创建可枚举的对象属性
在JavaScript中,可以使用Object.defineProperty()方法来创建可枚举的对象属性:
let person = {};
 
Object.defineProperty(person, "age", {
    value
评论已关闭