温故而知新 XD

1. 关于原型和构造函数的几个知识要点:

  1. 使用new 操作符调用构造函数,会经历以下四个步骤:

    1.1. 创建一个新对象;

    1.2. 将构造函数的作用域赋给新对象(因此 this 就指向了这个新对象);

    1.3. 执行构造函数中的代码(为这个新对象添加属性);

    1.4. 返回新对象。
  2. 当调用构造函数创建一个新实例后,该实例的内部将包含一个指针(内部属性:__proto__),指向构造函数的原型对象(所以可以在构造函数的 prototype 里存放实例公用的方法)。
  3. 每当代码读取某个对象的某个属性时,都会进行一次搜索,目标是具有给定名字的属性。搜索从对象实例本身开始。如果在实例中找到了该属性,则 return 该属性的值;如果没有找到,则搜索内部指针指向的原型对象( __proto__ ),若找到,则 return 该属性值;若没找到,继续搜索原型的原型...

2. 实现

给出父类 Animal,实现子类Cat:

function Animal (name) {
this.name = name
this.brother = 'Tony'
} Animal.prototype.eat = function (thing) {
console.log(this.name + ' eat ' + thing);
}

2.1 组合继承(结合原型链和借用构造函数,不太完美)

function Cat (name) {
Animal.call(this,name) // 借用构造函数,继承父类属性
this.sister = 'May'
} Cat.prototype = new Animal() // 原型链,继承父类方法
/* 在prototype继承了父类实例的全部属性,存在冗余。属性的继承已经在构造函数内通过调用父类构造函数实现。
实际上,子类的prototype需要的只是父类实例中指向父类原型的内部指针: Cat.prototype.__proto__ = Animal.protype */ console.log(Cat.prototype)
// {name: undefined(冗余), brother: "Tony"(冗余), constructor: ƒ} Cat.prototype.constructor = Cat // 由于上面 Cat.prototype 进行了赋值,所以需要重新指定其构造函数。
// 这一步对 instanceof 无影响,因为 "instanceof 运算符用来测试一个对象在其原型链中是否存在一个构造函数的 prototype 属性" ;影响的是Cat实例的constructor 属性。
// 如果不做这一步:var Tom = new Cat('Tom'); Tom.constructor ==> Animal

2.2 寄生组合继承(完美)

function Cat (name) {
Animal.call(this,name)
this.sister = 'May'
} function createObject (obj) { /* 创建一个新对象,使用现有的对象来提供新创建的对象的__proto__ ,相当于 Object.create() */
function F () {}
F.prototype = obj
return new F()
} Cat.prototype = createObject (Animal.prototype)
// 相当于 Cat.prototype = Object.create(Animal.prototype) console.log(Cat.prototype)
// {constructor: ƒ} Cat.prototype.constructor = Cat

2.3 ES6语法

class Animal {
constructor(name){
this.name = name
this.brother = 'Tony'
} eat(thing) {
console.log(this.name + ' eat ' + thing);
}
} class Cat extends Animal {
constructor(name) {
super(name)
/* super()表示调用父类构造函数,this指向子类。只有调用super之后,才可以使用this关键字,否则新建实例时会报错。*/
/* 另:super作为对象时,在普通方法中,指向父类的原型对象;在静态方法中,指向父类。通过super调用父类方法时,方法内部this指向子类;对super的猴哥属性赋值时,super就是this,赋值的属性会变成子类实例的属性 (不清楚里面是什么魔法)*/ this.sister = 'May'
}
}

温习js中对象的继承的更多相关文章

  1. js中对象转化成字符串、数字或布尔值的转化规则

    js中对象可以转化成 字符串.数字.布尔值 一.对象转化成字符串: 规则: 1.如果对象有toString方法,则调用该方法,并返回相应的结果:(代码通常会执行到这,因为在所有对象中都有toStrin ...

  2. 【转载】js中对象的使用

    原文链接:http://www.jb51.net/article/90256.htm[侵删] 简单记录javascript中对象的使用 一.创建对象 //创建一个空对象 var o={}; //创建一 ...

  3. [转]JS中对象与字符串的互相转换

    原文地址:http://www.cnblogs.com/luminji/p/3617160.html 在使用 JSON2.JS 文件的 JSON.parse(data) 方法时候,碰到了问题: thr ...

  4. JS中对象与字符串的互相转换

    在使用 JSON2.JS 文件的 JSON.parse(data) 方法时候,碰到了问题: throw new SyntaxError('JSON.parse'); 查询资料,大概意思如下: JSON ...

  5. js中对象的一些特性,JSON,scroll家族

    一.js中对象的一些特性 对象的动态特性 1.当对象有这个属性时,会对属性的值重写 2.当对象没有这个属性时,会为对象创建一个新属性,并赋值 获得对象的属性的方式 为元素设置DOM0级事件 二.JSO ...

  6. JS 中对象的简单创建和继承

    对象的简单创建 1.通过对象直接量创建 比如 var obj = {}; 2.通过new 创建 比如 var obj = new Object(); // 相当于var obj = {}; var a ...

  7. JS中对象继承方式

    JS对象继承方式 摘自<JavaScript的对象继承方式,有几种写法>,作者:peakedness 链接:https://my.oschina.net/u/3970421/blog/28 ...

  8. JS中原型链继承

    当我们通过构造函数A来实现一项功能的时候,而构造函数B中需要用到构造函数A中的属性或者方法,如果我们对B中的属性或者方法进行重写就会出现冗杂的代码,同时写出来也很是麻烦.而在js中每个函数都有个原型, ...

  9. [转] JS中简单的继承与多态

    这里讲了一个最最最简单的JS中基于原型链的继承和多态. 先看一下以下这段代码的实现(A是“父类”,B是“子类”): var A = function(){ this.value = 'a'; this ...

随机推荐

  1. LeetCode 386——字典序排数

    1. 题目 2. 解答 2.1 方法一 假设返回 118 以内数的字典顺序,则为 1,10,100,101,102,...,109,11,110,111,112,...,118,12,13,....根 ...

  2. 自定义View 和 ViewGroup

    一. 自定义View介绍 自定义View时, 继承View基类, 并实现其中的一些方法. (1) ~ (2) 方法与构造相关 (3) ~ (5) 方法与组件大小位置相关 (6) ~ (9) 方法与触摸 ...

  3. Spring中Controller和RequestMapping的详解

    先看一个简单的实例: @Controller @RequestMapping("/hello") public class anyTypeController{ @RequestM ...

  4. TCP系列38—拥塞控制—1、概述

    在本篇中我们继续上一篇文章wireshark的示例讲解,上一篇介绍了一个综合示例后,本篇介绍一些简单的示例,在读本篇前建议先把上一篇读完,为了节省篇幅,本篇只针对一些特殊的场景点报文进行讲解,不会像上 ...

  5. flash builder 4.6在debug调试时需要系统安装flashplayer debug版本

    http://blog.csdn.net/cupid0051/article/details/46684295

  6. Zigbee安全基础篇Part.1

    原文地址: https://www.4hou.com/wireless/14211.html 导语:ZigBee是一种开源无线技术,用于低功耗嵌入式设备(无线电系统).本文探讨了ZigBee协议的可用 ...

  7. exception = {"元数据集合中已存在具有标识“xxx”的项。\r\n参数名: item"}

    vs提示:exception = {"元数据集合中已存在具有标识"xxx"的项.\r\n参数名: item"} 出现这个错误说明有重复的字段,有可能是继承的类里 ...

  8. PHPcmsv9 还原数据库 操作步骤

    相比dedecms,相同之处:模版好制作,都是开源.不同之处:pc貌似有更好的 负载能力. 言归正传,这两天在捣鼓phpcmsv9程序,但是本地调试好了之后,无论是通过打包方式,还是 转移数据的方式. ...

  9. 第五部分shell项目一监控脚本

    需求: 使用shell定制各种个性化告警工具,但需要统一化管理.规范化管理. 思路:指定一个脚本包,包含主程序.子程序.配置文件.邮件引擎.输出日志等.主程序:作为整个脚本的入口,是整个系统的命脉.配 ...

  10. 织梦CMS建站入门学习(二)

    织梦建站的数据库设计: 1.模型表:根据网站的需求,建立不同的数据模型,如:文章浏览,软件下载,视频观看等等. 2.栏目表:根据网站的需求,建立不同的栏目,每一个栏目选择一个数据模型. 3.内容主表: ...