// 可以通过两种方式获取实例的原型对象
// 1) 实例.__proto__
// 2) Object.getPrototypeOf(实例)
// Object.getPrototypeOf(实例) === 构造函数.prototype
// 实例.constructor === 构造函数.prototype.constructor
// var a = Object.create(b) // Object.getPrototypeOf(a) === b
// 继承父类属性,可以通过call方法,范例如下:
function Person(name, age) {
this.name = name
this.age = age
}
function Student(name, age, sex) {
Person.call(this, name, age)
this.sex = sex
}
// 实现原型链继承,有两种方式:
// 1) 子构造函数.prototype = new 父构造函数()
// 2) 子构造函数.prototype = Object.create(父构造函数.prototype)
// 补充说明:推荐使用第二种方式,当父构造函数有形参时,语义化比第一种更好。这两种方式都需要把子构造函数的constructor属性改回来,子构造函数.prototype.constructor = 子构造函数
// 既继承父类属性,又继承父类原型链,最佳方式:
function Person(sex) {
this.sex = sex
}
Person.prototype.cry = function () {
console.log('哇哇哇...')
}
function Student(name, sex) {
Person.call(this, sex)
this.name = name
}
Student.prototype = Object.create(Person.prototype)
Student.prototype.constructor = Student
Student.prototype.study = function () {
console.log('正在学习...')
}
JS原型&原型链&继承
最新推荐文章于 2024-07-05 02:36:45 发布