原文:JS中通过call方法实现继承

讲解都写在注释里面了,有不对的地方请拍砖,谢谢!

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>JS通过call方法实现继承</title>
</head>
<body>
<script type="text/javascript"> /* js中的继承有多种实现方式,今天我们讨论下通过call方法实现的继承。 此方法与 原型链继承 相比还是比较简单,容易理解的。 那么,我们先对call方法进行简单的讲解: call 方法可以用一个对象来代替另一个对象调用一个方法。 这句话蛮不好理解, 还是看示例代码吧,更直观明了: */ function a() {
this.name = "我是a"; this.showName = function () {
alert(this.name);
}
} function b() {
this.name = "我是b";
} var _a = new a();
var _b = new b(); //下面这行代码的意思是:用 _b 来代替 _a 执行 _a 的showName方法。
//因此执行对象从 _a 变成了 _b, showName方法里面的this此时指代的是 b 了,而不是 a
//因此输出结果为: 我是b
_a.showName.call(_b); /*
哎,语文没学好,总感觉表达不清楚,也不知道大家能不能看懂。
好了,进入正题,我们来看继承的实现。
*/ /*
首先我们要定义4个类:动物(animal) ; 人(person) ; 中国人(chinese) ; 日本人(japanese)。 代码如下:
*/ function animal() {
this.eat = function () {
alert("动物都要吃东西");
}
} function person() {
this.say = function () {
alert("人是会说话的");
}
} // function chinese() {
// this.ch = function () {
// alert("我是中国人");
// }
// } // function japanese() {
// this.ja = function () {
// alert("我是日本人");
// }
// } /* 然后实现4个类之间的关系 关系如下: 中国人 继承自 人 日本人 继承自 动物 和 人 说明: 在JS中是可以实现类的多继承的。
因此 japanese 可以同时继承自 animal 和 person ,
它不像C#和java语言,只支持接口的多继承,而不支持类的多继承。 修改上面的chinese和japanese如下: */ function chinese() {
person.call(this); //继承自 person 类 (用chinese来代替person) this.ch = function () {
alert("我是中国人");
}
} function japanese() {
animal.call(this); //继承自 animal 类
person.call(this); //继承自 person 类 this.ja = function () {
alert("我是日本人");
}
} /*
我们知道:实现继承后,子类是可以拥有父类的公有字段和方法的。
而父类不会拥有子类的任何东西 说明:
js中的 字段,方法 也是有公有和私有之分的。
子类只能访问到父类的公有字段和方法。
关于 js 中的 公有,私有,全局,静态 等等的定义讲解我会另写一篇博文
与大家讨论。 请看如下代码:
*/ //实例化对象
var c = new chinese();
var j = new japanese();
var p = new person(); c.say(); //拥有父类 person 的 say 方法
c.ch(); //自身的 ch 方法 j.eat(); //拥有父类 animal 的 eat 方法
j.say(); //拥有父类 person 的 say 方法
j.ja(); //自身的 ja 方法 p.say(); //自身的 say 方法 /*
下面两句会报错,
因为父类person是不会拥有子类的任何东西的,
所以p没有ch和ja方法。 p.ch();
p.ja();
*/ </script>
</body>
</html>

     

JS中通过call方法实现继承的更多相关文章

  1. JS与OC交互,JS中调用OC方法(获取JSContext的方式)

    最近用到JS和OC原生方法调用的问题,查了许多资料都语焉不详,自己记录一下吧,如果有误欢迎联系我指出. JS中调用OC方法有三种方式: 1.通过获取JSContext的方式直接调用OC方法 2.通过继 ...

  2. js中的tostring()方法

    http://blog.sina.com.cn/s/blog_85c1dc100101bxgg.html js中的tostring()方法 (2013-11-12 11:07:43) 转载▼ 标签: ...

  3. 秒味课堂Angular js笔记------Angular js中的工具方法

    Angular js中的工具方法 angular.isArray angular.isDate angular.isDefined angular.isUndefined angular.isFunc ...

  4. jQuery与JS中的map()方法使用

    1.jquery中的map()方法 首先看一个简单的实例: $("p").append( $("input").map(function(){ return $ ...

  5. JavaScript -- 时光流逝(二):js中数组的方法

    JavaScript -- 知识点回顾篇(二):js中数组的方法 1. 数组 (1)定义数组,数组赋值 <script type="text/javascript"> ...

  6. ASP.NET#使用母版时,如果要使用js中的getElementById()方法取得某个内容页的元素时要注意的问题

    当使用母版,要使用js中的getElementById()方法取得某个内容页的元素时,所选取的id并不是母版中内容页的id,而是在设计内容页时设定的id例子:母版页: ...... <head ...

  7. JS中split使用方法和数组中元素的删除

    JS中split使用方法和数组中元素的删除 JS中split使用方法 <script language="javascript"> function spli(){ d ...

  8. JS中的splice方法

    JS中的splice方法 定义和用法 splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目. 注释:该方法会改变原始数组(集合). 语法 arrayObject.splice(ind ...

  9. JS中常见的几种继承方法

    1.原型链继承 // 1.原型链继承 /* 缺点:所有属性被共享,而且不能传递参数 */ function Person(name,age){ this.name = name this.age = ...

随机推荐

  1. Cocos2d-x使用Luajit将Lua脚本编译成bytecode,启用加密

    http://www.cocoachina.com/bbs/read.php?tid=205802 lua脚本进行加密,查了一下相关的资料 ,得知lua本身能够使用luac将脚本编译为字节码(byte ...

  2. linux中fork()函数具体解释(原创!!实例解说)

     一.fork入门知识 一个进程,包含代码.数据和分配给进程的资源.fork()函数通过系统调用创建一个与原来进程差点儿全然同样的进程,也就是两个进程能够做全然同样的事,但假设初始參数或者传入的变量不 ...

  3. 页面加速Chromium 预压 Prerendering

    前者已经推出了一个博客prefetch预加载的网页资源,以提高网页加载速度,下面我们一起来看一下,以加速网页chromium prerendering.介绍prerendering之前.先介绍两个概念 ...

  4. EJBCA于Linux安装在

    于windows为了测试安装,装在linuxserver因为CN使用ip需要重新加载.....再折腾.这里有一些地方需要注意 一.所需文件 内容准备不说,请参阅我在以前的文章<EJBCA于win ...

  5. 纯CSS3彩色边线3D立体按钮制作教程

    原文:纯CSS3彩色边线3D立体按钮制作教程 今天我们来分享一款利用纯CSS3实现的3D按钮,这款按钮的一个特点是有彩色的边线,这让整个按钮显得比较多姿多彩,没那么枯燥无趣.本文不仅可以让大家看到演示 ...

  6. sql 子查询stuff功能(同一个人的多任务,多领域成为字符串)

    USE [erp2015] GO /****** Object: StoredProcedure [dbo].[GetUser] Script Date: 03/14/2015 13:27:04 ** ...

  7. decimal system 2016

    Problem Description As we know , we always use the decimal system in our common life, even using the ...

  8. 教你Ant安装和配置

    Ant它是基于Java施工工具,它的主要作用是产生能够运行Java计划,把握Ant一些功能可以使项目更专业. 忙乱,可以在这里下载2014年8最近一个月Ant http://download.csdn ...

  9. 解决:&lt;net.sf.ehcache.util.UpdateChecker&gt; : New update(s) found: 2.6.5

    由于该项目采用ehcache,所以tomcat每次登录你开始打印net.sf.ehcache.util.UpdateChecker doCheck 一旦有没有特别关注.从今天开始 Tomcat 什么时 ...

  10. jquery扩展

    jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法.jQuery的全局函数就是属于jQuery命名空间的函数,另一种是对象级 ...