什么是继承?
拿来主义:自己没有,别人有,把别人的拿过来使用或者让其成为自己的

如何实现继承的方式

  • 原型继承
  • 混入继承
  • 经典继承

1. 混入继承

由于一个对象可以继承自任意的对象,即:o可以继承自对象o1,o2,o3...,所以,把这种继承称为:混入继承
  • 将其他对象中的成员加到自己身上
  • 对象可以继承自任意的对象
var o1 = {name:"女娲", age: 1, gender: "female"};
var o2 = {grade: "三年级二班", score: 100}; // o2 继承 o1
for ( var k in o1 ) {
o2[k] = o1[k];
} // 如果希望 o2 可以继承自任意的对象. 所以为了简化继承的代码
// 给 o2 提供一个方法, 叫 extend
o2.extend = function (obj) {
for (var k in obj) {
this[k] = obj[k];
}
} o2.extend(o1); // o2 继承 o1

2 原型继承

如果需要让一个对象拥有某些属性和方法,可以把这些属性和方法放到原型对象中,因为对象会继承自原型对象,所以就获得了该属性和方法。把这种继承方式称为:原型继承
  • 实现继承的方式
1 利用对象的动态特性  添加成员
2 覆盖原型对象 添加成员
3 利用混入继承 添加成员
  • 原型的一些结论
1 任何函数都可以作为构造函数
2 函数默认就有一个 prototype 属性
3 函数的prototype 就是 原型
4 构造函数的prototype的类型是对象
5 通过构造函数创建出来的对象默认链接到构造函数的prototype中
6 原型的成员(属性和方法)可以被对象共享

2.1 原型继承实现方式

  • 1 利用对象的动态特性
// 对象可以动态的添加属性
var o = {};
o.name = "川川";
o.age = 19;
o.gender = "男"; // -----------------------
function Person() {} // 将需要的属性添加到原型对象中
Person.prototype.sayHi = function() {}; var p = new Person();
p.sayHi();
  • 2 覆盖原型对象
Person.prototype = {
sayHi: function() {},
sayNo: function() {},
sayYouAgin: function() {}
};
注意:
使用覆盖原型对象方式实现继承的时候,
推荐给这个新对象添加一个 constructor 属性(属性的值为:当前的构造函数)
目的是保持和 默认情况的原型结构一样(模拟对象的类型) 但是如果对对象的类型要求不严格可以忽略 constructor: Person
  • 3 利用混入继承添加原型成员
对象2.extend( 对象1 )

3 经典继承 - Object.create

  • 1 创建对象
  • 2 让创建出来的对象继承自参数对象
诠释 继承是什么。

ES5提供的方法(IE9+ 开始支持)
提出者:Douglas Crockford(道格拉斯 克罗克福德) JSON作者 《JavaScript语言精粹》
作用:实现继承,即:让一个对象(o2)继承自另外一个对象(o1)
var o2 = Object.create( o1 );
  • 基本语法:
var o1 = {
sayHi: function() {
alert("hello,i am chuanchuan");
}
}; var o2 = Object.create(o1);
o2.sayHi();
  • 两种实现兼容的方式
// 1 给原生对象添加成员
if(!Object.create) {
Object.create = function() {
// 构造函数
function F() {}
// 继承
F.prototype = obj;
return new F();
};
} // 2 统一使用新方法(推荐)
var create = function( obj ) {
if ( Object.create ) {
return Object.create( obj );
} else { function F() {}
F.prototype = obj;
return new F();
}
}

谈谈javascript中原型继承的更多相关文章

  1. 谈谈javascript中的prototype与继承

    谈谈javascript中的prototype与继承 今天想谈谈javascript中的prototype. 通常来说,javascript中的对象就是一个指向prototype的指针和一个自身的属性 ...

  2. JavaScript中的继承(原型链)

    一.原型链 ECMAScript中将原型链作为实现继承的主要方法,基本思想是利用原型让一个引用类型继承另一个引用类型的属性和方法. 实例1: function SupType() { this.pro ...

  3. JavaScript学习13 JavaScript中的继承

    JavaScript学习13 JavaScript中的继承 继承第一种方式:对象冒充 <script type="text/javascript"> //继承第一种方式 ...

  4. 浅谈JavaScript中的继承

    引言 在JavaScript中,实现继承的主要方式是通过原型链技术.这一篇文章我们就通过介绍JavaScript中实现继承的几种方式来慢慢领会JavaScript中继承实现的点点滴滴. 原型链介绍 原 ...

  5. JavaScript的原型继承

    JavaScript是一门面向对象的语言.在JavaScript中有一句很经典的话,万物皆对象.既然是面向对象的,那就有面向对象的三大特征:封装.继承.多态.这里讲的是JavaScript的继承,其他 ...

  6. 彻底搞懂JavaScript中的继承

    你应该知道,JavaScript是一门基于原型链的语言,而我们今天的主题 -- "继承"就和"原型链"这一概念息息相关.甚至可以说,所谓的"原型链&q ...

  7. 浅谈 JavaScript 中的继承模式

    最近在读一本设计模式的书,书中的开头部分就讲了一下 JavaScript 中的继承,阅读之后写下了这篇博客作为笔记.毕竟好记性不如烂笔头. JavaScript 是一门面向对象的语言,但是 ES6 之 ...

  8. 关于JavaScript中实现继承,及prototype属性

    感谢Mozilla 让我弄懂继承. JavaScript有八种基本类型,函数属于object.所以所有函数都继承自object.//扩展:对象,基本上 JavaScript 里的任何东西都是对象,而且 ...

  9. javascript中各种继承方式的优缺点

    javascript中实现继承的方式有很多种,一般都是通过原型链和构造函数来实现.下面对各种实现方式进行分析,总结各自的优缺点. 一 原型继承 let Super = functioin(name = ...

随机推荐

  1. 京东专业“卖”队友,魅族手环将亮相1206魅蓝note新品发布会

    京东一直是国内顶级的数码产品自营销售渠道,但是,正因为庞大的数据体系和平台特殊性,经常会帮我们发现一些“好玩的”保密性较高的东西,譬如价格.信息.谍照等.而在最新上线的京东超级品牌日活动页面上,专业“ ...

  2. 软件神器系列——photozoom图片像无损清晰放大软件砸金蛋活动开始啦!

    不管是刚进入社会的小白,还是混迹多年的油条,是不是发现了最近的工作越来越难做了? 推广文章.产品手册.营销方案.培训计划.工作报告乃至于PPT,都不是以前用文字数据可以交工的了,现在都讲究“图文并茂” ...

  3. 1520dc更新与NUll语句用法

    update dbo.dc_出租信息set 出租类型 = 1where 出租类型='普通楼上房' update dbo.dc_出租信息set 朝向 = 5where 朝向 is NULL

  4. 64 求1+2+3+...+n(发散思维能力 )

    题目描述: 求1+2+3+...+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字及条件判断语句(A?B:C). 解题思路: 1)利用&&的短 ...

  5. LCA 最近公共祖先 (笔记、模板)

    求lca的方法大体有三种: 1.dfs+RMQ(线段树 ST表什么的) 在线 2.倍增 在线 3.tarjan 离线 ps:离线:所有查询全输入后一次解决 在线:有一个查询输出一次 以下模板题为 洛谷 ...

  6. adb简单使用

    一.基本命令 1.查看目前连接的设备/虚拟器的状态 adb devices

  7. bitset骚操作

    bitset的用途挺多的,是一个比较骚的常数优化 一.很多位数的二进制数 poj 2443 http://poj.org/problem?id=2443 直接开个1万位的二进制数,求交就行了. 有关集 ...

  8. php中的form表单

    表单处理 表单的概念在生活中很常见,就像是问卷调查表一样,别人先把问卷发给你,你照着问卷的要求填写,完事过后再将填完的问卷发给别人,从而达到一个将别人需要的信息传递给别人的一种方式. 传统的网页大多数 ...

  9. 企业级工作流解决方案(十三)--集成Abp和ng-alain--数据库读写分离

    说到程序里面数据库管理,无非就是两件事情,一是数据库操作,对于数据库的操作,各种程序语言都有封装,也就是所谓的ORM框架,.net 方向一般用得比较多和就是.net framework和dapper, ...

  10. HDU6010 Daylight Saving Time

    /* HDU6010 Daylight Saving Time http://acm.hdu.edu.cn/showproblem.php?pid=6010 模拟 题意:算当前时间是否是夏令时 */ ...