经典继承

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. [CF780C]Andryusha and Colored Balloons 题解

    前言 完了,完了,咕值要没了,赶紧写题解QAQ. 题意简述 给相邻的三个节点颜色不能相同的树染色所需的最小颜色数. 题解 这道题目很显然可以用深搜. 考虑题目的限制,如果当前搜索到的点为u, 显然u的 ...

  2. JMS学习九(ActiveMQ的消息持久化到Mysql数据库)

    1.将连接Mysql数据库的jar文件,放到ActiveMQ的lib目录下 2.修改ActiveMQ的conf目录下的active.xml文件,修改数据持久化的方式 2.1  修改原来的kshadb的 ...

  3. Oracle 字符串拼接会出现0自动忽略,解决方案

    解决方案 ,),'||num,num) from table_name 参考:https://blog.csdn.net/menghuannvxia/article/details/73089903

  4. Bootstrap Table 的X-editable插件怎么用

    在准备使用X-editable来做Bootstrap Table 的行内编辑的时候,根据http://www.cnblogs.com/landea... 的文章,我不能将全部效果重复实现,网上也搜索了 ...

  5. webpack.config.js文件

    与 package.json 配合使用 var path=require("path");var OpenBrowserPlugin = require('open-browser ...

  6. LeetCode_509.斐波那契数

    LeetCode-cn_509 509.斐波那契数 斐波那契数,通常用 F(n) 表示,形成的序列称为斐波那契数列.该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和.也就是: F(0) ...

  7. Python可变数据类型list填坑一则

    前提概要 最近写业务代码时遇到一个列表的坑,在此记录一下. 需求 现在有一个普通的rule列表: rule = [["ID",">",0]] 在其他地方经 ...

  8. k8s 添加ingress 暴露服务

    vim file.yaml apiVersion: extensions/v1beta1 kind: Ingress metadata: name: pgadmin labels: k8s-app: ...

  9. Eclipse高版本无法兼容FatJar的问题解决

    发现eclipse打包jar无法连带打包第三方lib,于是选择安装插件fatjar,现在说明fatjar安装过程: 1.安装方法:   1)下载安装:   https://sourceforge.ne ...

  10. 【flask】项目集成Sentry收集线上错误日志

    flask集成sentry分为4个步骤: 首先在sentry官网注册1个账号 然后创建1个新的项目,这里我选择的是flask,这会得到一些关于sdk的使用说明 接下来创建一个简单的flask项目使用s ...