博客
关于我
回想继承、原型与原型链有感
阅读量:450 次
发布时间:2019-03-06

本文共 1639 字,大约阅读时间需要 5 分钟。

首先需要明确以下几点:

1. js中除了Object.prototype和null之外,每一个对象都有一个原型对象。

2. 获取原型对象: 实例对象通过__proto__,构造函数通过prototype。

3. Object.defineProperty()和Object.assign()之类的函数(不在原型链上的函数)是不能通过继承获得的。

4. arguments.callee需要在函数声明的时候调用,arguments.caller需要在函数执行的时候调用。

5. 每个对象的构造函数都在其原型对象上。

 

除了ES6中的继承之外,我们常用的有以下三种:

*注意:网上有很多分享都说用call继承属性,用原型链拷贝继承方法。这种观点是错误的。用call同样可以继承方法,但,此方法必须是当前实例对象上的方法,而不是原型链上的方法。用原型链也一样可以继承属性,但,此属性必须是原型链上的,而非实例对象本身的。

1.俗称类式继承

通过call或apply实现实例对象的属性或方法(this.XXXXX)的继承

通过 B.prototype = new A() 实现原型链上的属性或方法的继承
通过 B.prototype.constructor = A 实现constructor的指向更正

function People (name, age) {    this.name = name;    this.age = age;    this.eat = function () {        console.log(this.name + ": people eat !");    };}People.prototype.protoEat = function () {    console.log(this.name + "proto eat !!");}function Student (name, age) {    People.call(this, name, age);    Student.prototype.constructor = Student;}Student.prototype = new People();

2.俗称拷贝继承

通过call或apply实现实例对象的属性或方法(this.XXXXX)的继承

通过 循环 B.prototype[i] = A.prototype[i] 实现对原型链上的属性或方法的继承

function People (name, age) {    this.name = name;    this.age = age;    this.eat = function () {        console.log(this.name + ": eat !")    }}People.prototype.protoEat = function () {    console.log(this.name + "proto eat !!");}function Student (name, age) {    People.call(this, name, age);}for(var i in People.prototype){    Student.prototype[i] = People.prototype[i]}

3.普通对象做顶层进行向下继承

相当于是只通过原型继承了原型链上的属性和方法

var obj = {name: "People", eat: function () {console.log("eat fn !")}};function clone (obj) {    var Fn = function () {};    Fn.prototype = obj;    return new Fn();}var tt = clone(obj)tt.eat();

 

转载地址:http://isufz.baihongyu.com/

你可能感兴趣的文章
ngModelController
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>