1、对象冒充
先创建一个Person类:
function Person(name, age){
this.name = name
this.age = age
this.sayHello = function(){
alert("Hello, I'm " + this.name + ".")
}
}
接着要创建一个Employee类,这个类有Person所拥有的name和age属性,另外还有自己的salary属性和showMeTheMoney()方法,可以这么做:
function Employee(name, age, salary){
this.newMethod = Person
this.newMethod(name, age)
delete this.newMethod
this.salary = salary
this.showMeTheMoney = function(){
alert(this.name + "$" + this.salary)
}
}
上面代码看起来有些复杂,其实它只是把Person当作单纯的函数,在Employee构造的时候调用一遍罢了。这个newMethod只用于构造对象,构造完毕后就没有用处,所以用完之后可以用delete操作符将其删除。
2、call()方法
每个function对象都有一个call()方法,它的第一个参数是用作this的对象,其它参数都直接传递给函数自身。例如:
function say(word){
alert(word + ", I'm " + this.name)
}
var yuan = new Object
yuan.name = "yuan"
say.call(yuan, "Hello") //alert: Hello, I'm yuan
利用call方法,可以简化前面的Employee代码:
function Employee(name, age, salary){
//this.newMethod = Person
//this.newMethod(name, age)
//delete this.newMethod
Person.call(this, name, age)//前面三行代码用这一行代替了
this.salary = salary
this.showMeTheMoney = function(){
alert(this.name + "$" + this.salary)
}
}
3、apply()方法
和call()方法一样,每个function对象都有一个apply()方法,它的第1个参数和call()方法一样,第2个参数是一个数组,这个数组是要传给function的参数的数组。用apply()改写上面的代码:
function Employee(name, age, salary){
//Person.call(this, name, age)
Person.apply(this, [name, age])
this.salary = salary
this.showMeTheMoney = function(){
alert(this.name + "$" + this.salary)
}
}
4、原型链
function对象的prototype属性是个模板,要实例化的对象都以这个模板为基础。(详见
这里)总之,prototype的任何属性和方法(方法也是一种属性)都被传递给那个“类”的所有实例。那我们就可以给某个function的prototype直接赋值为某个对象,这样的话,这个被赋值的对象的所有属性和方法都将被传递给这个function构造出来的实例,可以利用这一点实现继承机制。
之前说过:属性由构造函数定义,方法由原型(prototype)定义,所以可以将上面的代码再次修改如下:
//定义Person类
function Person(name, age){
this.name = name
this.age = age
}
Person.prototype.sayHello = function(){
alert("Hello, I'm " + this.name + ".")
}
//定义Employee类
function Employee(name, age, salary){
//Person.call(this, name, age)
Person.apply(this, [name, age])
this.salary = salary
}
Employee.prototype = new Person
Employee.prototype.showMeTheMoney = function(){
alert(this.name + "$" + this.salary)
}
这里,new Person创建了一个Person对象,它有Person对象的所有属性和方法,把它赋值给Employee的prototype意味着Employee构造出来的所有实例都将拥有Person的属性和方法。这样便实现了继承。
在原型链中,instanceof运算符的运行方式很独特。对Employee的所有实例,instanceof为Employee和Person都返回true。
分享到:
相关推荐
JavaScript中的继承是面向对象编程的重要概念,它允许一个对象(子对象)继承另一个对象(父对象)的属性和方法。在JavaScript中,由于其动态类型和基于原型的特性,实现继承的方式比传统的面向对象语言更为灵活,但...
在给定的文件内容中,我们看到一个具体的JavaScript继承的例子,主要分为以下几个步骤: 1. 定义父类`Person`,这个类有一个原型方法`walk`和`sayHello`,它们分别用于定义行走和打招呼的行为。 ```javascript ...
JavaScript继承是面向对象编程(OOP)中的一个核心概念,它允许一个对象(称为子类或派生类)继承另一个对象(称为父类或基类)的属性和方法。JavaScript是一种基于原型的编程语言,它实现继承的方式与其他基于类的...
JavaScript 中继承的实现 怎么建? git clone 这个仓库 切换到新目录 npm install npm run build 用法 var Person = BaseObject . extend ( { init : function ( name , age ) { this . name = name ; this . ...
JavaScript中的继承是一个核心概念,它在面向对象编程中扮演着至关重要的角色。与其他面向对象语言相比,JavaScript的继承机制更为复杂。在Java或C++等语言中,继承通常只需要一个关键字,如`extends`,但在...
详细介绍了JavaScript中继承的实现方式以及其优缺点分析。
寄生组合继承解决了组合继承中父类构造函数会被调用两次的问题,通过创建父类的一个不被使用的实例,然后将子类的原型指向这个实例的原型。 ```javascript function inheritPrototype(subType, superType) { let ...
在JavaScript中,选择合适的继承方式取决于具体需求。理解并熟练掌握这些继承方式,能让你在编写代码时更加游刃有余。文章中的`inheritance.html`和`inheritance.js`文件可能包含示例代码,帮助你直观地了解每种继承...
在这个主题中,“javascript控件开发之继承关系”主要探讨的是如何利用JavaScript的面向对象特性来构建和组织控件的层次结构,以及如何通过继承来实现代码的复用和模块化。 在JavaScript中,继承是基于原型...
JavaScript中的类继承是一种模拟传统面向对象编程中类概念的方式,因为JavaScript本身是一种基于原型的面向对象语言。在JavaScript中,对象可以直接从其他对象继承属性和方法,而不是通过类的实例化。这种继承机制...
在原型链继承中,子类型的原型对象指向父类型的实例,从而使得子类型的实例可以继承父类型原型上的属性和方法。原型链继承允许子类型访问父类型的实例属性和方法,这在JavaScript中是通过设置子类型的prototype指向...
本文将详细介绍六种实现JavaScript继承的方法。 1. 原型链继承 原型链继承是通过改变子类型的原型对象来实现继承的。子类型构造函数的原型被替换为超类型构造函数的一个实例,这样子类型就可以继承超类型的所有属性...
JavaScript 中的继承机制是指子类继承父类的属性和方法,使得子类可以拥有父类的所有特征。继承是面向对象编程的基本机制之一,它可以实现代码复用、提高编程效率和增强代码的可维护性。 在 JavaScript 中,继承是...
在JavaScript中,原型继承是一种非常核心且独特的机制,它使得对象能够继承其他对象的属性和方法。本文旨在深入探讨这一机制,并通过具体的示例代码帮助读者更好地理解其中的概念。 #### 二、基本概念 在JavaScript...
在本文中,我们将深入探讨JavaScript继承机制的实现方式,并对基于原型的继承、构造函数方式继承、组合继承、寄生式继承等继承机制进行了总结归纳和分析。 基于原型的继承 JavaScript是一门基于原型的语言,它不像...