经典继承

js中实现经典继承的方式是通过构造函数来实现的,即在子类中对父类调用call方法。

  function Geometric() {
this.time = "";
this.color = "";
this.base = function () {
alert("Creating time is: " + this.time + " and color is: " + this.color)
}
} function Circle() {
Geometric.call(this);
this.radius = 0;
this.area = function () {
alert("the area is: " + Math.PI * this.radius * this.radius) }
}
function Rectangle() {
Geometric.call(this);
this.wi = 0;
this.he = 0;
this.area = function () {
alert("the area is: " + this.wi * this.he)
}
}
var instance1 = new Circle() instance1.time = "20xx.xx.xx"
instance1.color = "red"
instance1.radius = 0.3;
instance1.area()
instance1.base() var instance2 = new Rectangle()
instance2.time = "20xx.xx.xx"
instance2.color = "blue"
instance2.wi = 3;
instance2.he = 4;
instance2.area();
instance2.base();

  

组合继承

组合继承又称伪经典继承,是通过原型链(实现对原型属性和方法的继承) +借用构造函数(实现对实例属性的继承) 。

父类的方法定义在父类的原型上;子类中继续进行父类的call方法的调用;让子类的原型指向父类;子类的方法定义在子类原型上。

  //组合继承
//原型链+借用构造函数
function Geometric() {
this.time = "";
this.color = ""; }
//方法定义在构造函数的原型上
Geometric.prototype.base = function () {
alert("Creating time is: " + this.time + " and color is: " + this.color)
} function Circle() {
Geometric.call(this);
this.radius = 0; }
Circle.prototype = new Geometric()
Circle.prototype.area = function () {
alert("the area is: " + Math.PI * this.radius * this.radius)
}
var instance3 = new Circle();
instance3.time = "20xx.xx.xx"
instance3.color = "green";
instance3.radius = "20"
instance3.base();
instance3.area();

原型式继承

原型式继承使用了一个空函数对象F来作为原型链的中间变量。

父类的方法定义在父类的原型上;子类中继续进行父类call方法的调用;构造一个空函数对象F;让F的原型=父类的原型;子类的原型=F;子类原型的构造函数=子类;子类的方法构造在子类原型上。

  //原型式继承
//使用一个空函数F来当做中间对象
function Geometric() {
this.time = "";
this.color = ""; }
//方法定义在构造函数的原型上
Geometric.prototype.base = function () {
alert("Creating time is: " + this.time + " and color is: " + this.color)
}
function Circle() {
Geometric.call(this);
this.radius = 0; } function F() { }
F.prototype = Geometric.prototype;
Circle.prototype = new F()
Circle.prototype.constructor = Circle(); Circle.prototype.area = function () {
alert("the area is: " + Math.PI * this.radius * this.radius)
} var instance4 = new Circle();
instance4.time = "2018.06.03"
instance4.color = "green";
instance4.radius = "20"
instance4.base();
instance4.area();
alert(instance4.__proto__ == Circle.prototype)
alert(instance4.__proto__.__proto__ == Geometric.prototype)

寄生继承

寄生继承了创建一个用于封装继承过程的函数。

创建一个继承函数;传入一个父类对象;在函数内构造该父类对象;在函数内创建子类;return该父类对象;

//寄生继承
//创建一个用于封装继承过程的函数
function createGeometric(g) {
var clone1 = Object(g);
clone1.createCircle = function (radius) {
this.radius = radius;
this.circleArea = function () {
alert("the area is: " + Math.PI * this.radius * this.radius) }
}
clone1.createRectangle = function (wi, he) {
this.wi = wi;
this.he = he;
this.rectangleArea = function () {
alert("the area is: " + this.wi * this.he);
}
}
clone1.base = function () {
alert("Creating time is: " + g.time + " and color is: " + g.color)
}
//最后要将新创建的对象return出去
return clone1
}
var g = {
time: "20xx.xx.xx",
color: "red"
} var Geometric = createGeometric(g); Geometric.base();
Geometric.createCircle(2.0);
alert(Geometric.circleArea())
Geometric.createRectangle(4, 5);
alert(Geometric.rectangleArea())

寄生组合继承

寄生组合继承避免了组合继承中的一些冗余现象。

组合继承中:子类中进行了父类call方法的调用;子类的原型指向父类;这样就会有一定的冗余。

寄生组合继承中,通过一个函数(此处写为inheritPrototype)来代替子类的原型指向父类这一过程

    //寄生组合继承,避免了组合继承中的冗余现象
function inheritPrototype(subType, superType) {
var protoType = Object.create(superType.prototype); //创建对象
protoType.constructor = subType; //增强对象
subType.prototype = protoType; //指定对象
} function Geometric() {
this.time = "";
this.color = ""; }
//方法定义在构造函数的原型上
Geometric.prototype.base = function () {
alert("Creating time is: " + this.time + " and color is: " + this.color)
} function Circle() {
Geometric.call(this);
this.radius = 0; }
//Circle.prototype = new Geometric()
inheritPrototype(Circle, Geometric)
Circle.prototype.area = function () {
alert("the area is: " + Math.PI * this.radius * this.radius)
}
var instance5 = new Circle();
instance5.time = "20xx.xx.xx"
instance5.color = "green";
instance5.radius = "20"
instance5.base();
instance5.area();

javascript学习笔记--经典继承、组合继承、原型式继承、寄生继承以及寄生组合继承的更多相关文章

  1. Java程序猿JavaScript学习笔记(2——复制和继承财产)

    计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...

  2. Java程序猿的JavaScript学习笔记(6——面向对象模拟)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  3. Java程序猿的JavaScript学习笔记(汇总文件夹)

    最终完结了,历时半个月. 内容包含: JavaScript面向对象特性分析,JavaScript高手必经之路. jQuery源代码级解析. jQuery EasyUI源代码级解析. Java程序猿的J ...

  4. Java程序猿的JavaScript学习笔记(8——jQuery选择器)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  5. Java程序猿的JavaScript学习笔记(3——this/call/apply)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  6. Java程序猿JavaScript学习笔记(4——关闭/getter/setter)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

  7. Java程序猿JavaScript学习笔记(14——扩大jQuery UI)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

  8. javascript学习笔记(四) Number 数字类型

    数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数  toExponential() 方法 用科学 ...

  9. Java程序猿的JavaScript学习笔记(1——理念)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

随机推荐

  1. 用java imageio调整图片DPI,例如从96调整为300

    因项目需求把图片的DPI值提升到300,否则OCR识别产生错乱:直接上源码:1.图片处理接口: package util.image.dpi; import java.awt.image.Buffer ...

  2. net core 返回值

    //指定类下的子类 Type helloType = typeof(ActionResult); List<Type> types = new List<Type>(); fo ...

  3. 手动安装jar包到maven仓库

    1.手动安装jar包到maven仓库 本地没有下载安装maven,但是eclipse已经集成的maven. 选中任何一个maven项目,右键/Run as/maven build... 在Goals输 ...

  4. 洛谷 P1282 多米诺骨牌 ( 线性DP )

    题意 : 题目链接 分析 :  一开始这个想法也有想到,但是貌似要开很大数组,就感觉应该不行 遂放弃想其他方法,万万没想到注意到可以滚动优化(其实不优化也可以过) 定义 dp[i][j] 表示 到第 ...

  5. JUnit——单元测试步骤

    步骤: 1. New Package(一般命名为*.Test,测试类与开发类放在不同的包中)2. New JUnit Text Case(一般命名为*Test)3. 选择需要测试的方法 4. 可以下载 ...

  6. 51 Nod 1678 lyk与gcd(容斥原理)

    1678 lyk与gcd  基准时间限制:2 秒 空间限制:131072 KB 分值: 80 难度:5级算法题  收藏  关注 这天,lyk又和gcd杠上了. 它拥有一个n个数的数列,它想实现两种操作 ...

  7. c++ STL map 用法

    map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据 处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时 ...

  8. zookeeper3.5.5集群部署

    ZooKeeper是一个为分布式应用所设计的分布的.开源的协调服务,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,简化分布式应用协调及其管理的难度,提供高性能的分布式服务.ZooKeeper ...

  9. SpringCloud 入门知识篇

    SpringCloud 入门 springcloud 学习 7天学会springcloud 教程 https://www.cnblogs.com/skyblog/category/738524.htm ...

  10. OverFeat:基于卷积网络的集成识别、定位与检测

    摘要:我们提出了一个使用卷积网络进行分类.定位和检测的集成框架.我们展示了如何在ConvNet中有效地实现多尺度和滑动窗口方法.我们还介绍了一种新的深度学习方法,通过学习预测对象边界来定位.然后通过边 ...