javascript继承

上传人:hs****ma 文档编号:560212664 上传时间:2023-03-02 格式:DOC 页数:55 大小:189.50KB
返回 下载 相关 举报
javascript继承_第1页
第1页 / 共55页
javascript继承_第2页
第2页 / 共55页
javascript继承_第3页
第3页 / 共55页
javascript继承_第4页
第4页 / 共55页
javascript继承_第5页
第5页 / 共55页
点击查看更多>>
资源描述

《javascript继承》由会员分享,可在线阅读,更多相关《javascript继承(55页珍藏版)》请在金锄头文库上搜索。

1、javascript继承面向对象与基于对象几乎每个开发人员都有面向对象语言(比如C+、C#、Java)的开发经验。 在传统面向对象的语言中,有两个非常重要的概念 - 类和实例。 类定义了一类事物公共的行为和方法;而实例则是类的一个具体实现。 我们还知道,面向对象编程有三个重要的概念 - 封装、继承和多态。 但是在JavaScript的世界中,所有的这一切特性似乎都不存在。 因为JavaScript本身不是面向对象的语言,而是基于对象的语言。 这里面就有一些有趣的特性,比如JavaScript中所有事物都是对象, 包括字符串、数组、日期、数字,甚至是函数,比如下面这个例子: ?123456789

2、10/ 定义一个函数 - add function add(a, b) add.invokeTimes+; return a + b; / 因为函数本身也是对象,这里为函数add定义一个属性,用来记录此函数被调用的次数 add.invokeTimes = 0; add(1 + 1); add(2 + 3); console.log(add.invokeTimes); / 2 模拟JavaScript中类和继承在面向对象的语言中,我们使用类来创建一个自定义对象。然而JavaScript中所有事物都是对象,那么用什么办法来创建自定义对象呢? 这就需要引入另外一个概念 - 原型(prototype)

3、,我们可以简单的把prototype看做是一个模版,新创建的自定义对象都是这个模版(prototype)的一个拷贝 (实际上不是拷贝而是链接,只不过这种链接是不可见,给人们的感觉好像是拷贝)。 让我们看一下通过prototype创建自定义对象的一个例子: ?1234567891011121314/ 构造函数 function Person(name, sex) this.name = name; this.sex = sex; / 定义Person的原型,原型中的属性可以被自定义对象引用 Person.prototype = getName: function() return this.na

4、me; , getSex: function() return this.sex; 这里我们把函数Person称为构造函数,也就是创建自定义对象的函数。可以看出,JavaScript通过构造函数和原型的方式模拟实现了类的功能。 创建自定义对象(实例化类)的代码: ?12345var zhang = new Person(ZhangSan, man); console.log(zhang.getName(); / ZhangSan var chun = new Person(ChunHua, woman); console.log(chun.getName(); / ChunHua 当代码var

5、 zhang = new Person(ZhangSan, man)执行时,其实内部做了如下几件事情: 创建一个空白对象(new Object())。 拷贝Person.prototype中的属性(键值对)到这个空对象中(我们前面提到,内部实现时不是拷贝而是一个隐藏的链接)。 将这个对象通过this关键字传递到构造函数中并执行构造函数。 将这个对象赋值给变量zhang。 为了证明prototype模版并不是被拷贝到实例化的对象中,而是一种链接的方式,请看如下代码: ?1234567891011121314function Person(name, sex) this.name = name;

6、this.sex = sex; Person.prototype.age = 20; var zhang = new Person(ZhangSan, man); console.log(zhang.age); / 20 / 覆盖prototype中的age属性 zhang.age = 19; console.log(zhang.age); / 19 delete zhang.age; / 在删除实例属性age后,此属性值又从prototype中获取 console.log(zhang.age); / 20 这种在JavaScript内部实现的隐藏的prototype链接,是JavaScrip

7、t赖以生存的温润土壤, 也是模拟实现继承的基础。 如何在JavaScript中实现简单的继承? 下面的例子将创建一个雇员类Employee,它从Person继承了原型prototype中的所有属性。 ?1234567891011121314function Employee(name, sex, employeeID) this.name = name; this.sex = sex; this.employeeID = employeeID; / 将Employee的原型指向Person的一个实例 / 因为Person的实例可以调用Person原型中的方法, 所以Employee的实例也可以

8、调用Person原型中的所有属性。 Employee.prototype = new Person(); Employee.prototype.getEmployeeID = function() return this.employeeID; ; var zhang = new Employee(ZhangSan, man, 1234); console.log(zhang.getName(); / ZhangSan 上面关于继承的实现很粗糙,并且存在很多问题: 在创建Employee构造函数和原型(以后简称类)时,就对Person进行了实例化,这是不合适的。 Employee的构造函数没法

9、调用父类Person的构造函数,导致在Employee构造函数中对name和sex属性的重复赋值。 Employee中的函数会覆盖Person中的同名函数,没有重载的机制(和上一条是一个类型的问题)。 创建JavaScript类的语法过于零散,不如C#/Java中的语法优雅。 实现中有constructor属性的指向错误,这个会在第二篇文章中讨论。 我们会在第三章完善这个例子。 JavaScript继承的实现正因为JavaScript本身没有完整的类和继承的实现,并且我们也看到通过手工实现的方式存在很多问题, 因此对于这个富有挑战性的任务网上已经有很多实现了: Douglas Crockfor

10、d - Prototypal Inheritance in JavaScript Douglas Crockford - Classical Inheritance in JavaScript John Resig - Simple JavaScript Inheritance Dean Edwards - A Base Class for JavaScript Inheritance Prototype Mootools Extjs this this表示当前对象,如果在全局作用范围内使用this,则指代当前页面对象window; 如果在函数中使用this,则this指代什么是根据运行时此函

11、数在什么对象上被调用。 我们还可以使用apply和call两个全局方法来改变函数中this的具体指向。 先看一个在全局作用范围内使用this的例子: console.log(this = window); / true console.log(window.alert = this.alert); / true console.log(this.parseInt(021, 10); / 10 函数中的this是在运行时决定的,而不是函数定义时,如下: / 定义一个全局函数 function foo() console.log(this.fruit); / 定义一个全局变量,等价于window.

12、fruit = apple; var fruit = apple; / 此时函数foo中this指向window对象 / 这种调用方式和window.foo();是完全等价的 foo(); / apple / 自定义一个对象,并将此对象的属性foo指向全局函数foo var pack = fruit: orange, foo: foo ; / 此时函数foo中this指向window.pack对象 pack.foo(); / orange 全局函数apply和call可以用来改变函数中this的指向,如下: / 定义一个全局函数 function foo() console.log(this.fruit); / 定义一个全局变量 var fruit = apple; / 自定义一个对象 var pack = fruit: orange ; / 等价于window.foo(); foo.apply(window); / apple / 此时foo中的this = pack foo.apply(pack); / orange 注:apply和call两个函数的作用相同,唯一的区别是两个函数的参数定义不同。 因为在JavaScript中函数也是对象,所以我们

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号