js面向对象

作者: Wendy曹 | 来源:发表于2017-08-22 00:12 被阅读325次

前段时间刷知乎看到一个面试题,要讲讲原型链、构造函数、对象之间的联系,特地拿出红宝书整理出思维导图,加深下印象。


面向对象.png

关于继承的三个方式的代码,由于篇幅较长,不便写在原型中,所以以下整理出来。
1、原型链继承

function Chinese(){
  this.hairColor = 'black';
}
Chinese.prototype.getHairColor = function(){
  return this.hairColor;
}
function Coder(){
  this.hairColor = 'white';
}
//继承了Chinese
Coder.prototype = new Chinese();
Coder.prototype.getHairColor = function(){
  return this.hairColor;
}
var coder1 = new Coder();
alert(coder.getHairColor());     //white

例子中实例、构造函数及原型的联系如图:

原型链.png

2、借用构造函数继承

function Chinese(){
  this.hairColor = ['black','blue','green'];
}
function Coder (){
  //继承了Chinese
  Chinese.call(this);
}
var coder1 = new Coder();
coder1.color.push("white");
alert(color1.color);  //"black, blue, green, white"
var coder2 = new Coder();
alert(coder2.color);  //"black, blue, green"

3、组合继承

function Person(name){
  this.name = name;
}
SuperType.prototype.sayName = function(){
  alert(this.name);
}
function Children(name, age){
  //继承属性
  Person.call(this, name);
  this.age = age;
}
//继承方法 
Children.protoType = new Person();
Children.protoType.sayAge = function(){
  alert(this.age);
}
var children1 = new Children("Nicholas", 9);
children1.sayName();       //"Nicholas"
children1.sayAge();           //9
var children2 = new SubType("Wendy", 10);
children2.sayName();      //"Wendy"
children2.sayAge();          //10

剧终。。。
『写得不好的地方请大胆吐槽,非常感谢大家带我进步。』

相关文章

  • JS面向对象精要(二)_函数

    JS面向对象精要(一)_原始类型和引用类型JS面向对象精要(二)_函数JS面向对象精要(三)_理解对象JS面向对象...

  • JS面向对象精要(三)_理解对象

    JS面向对象精要(一)_原始类型和引用类型JS面向对象精要(二)_函数JS面向对象精要(三)_理解对象JS面向对象...

  • JS面向对象精要(四)_构造函数和原型对象

    JS面向对象精要(一)_原始类型和引用类型JS面向对象精要(二)_函数JS面向对象精要(三)_理解对象JS面向对象...

  • JS面向对象精要(五)_继承

    JS面向对象精要(一)_原始类型和引用类型JS面向对象精要(二)_函数JS面向对象精要(三)_理解对象JS面向对象...

  • js 面向对象和面向过程

    js 面向对象和面向过程

  • 面向对象OOP--JS

    作者:烨竹 JS面向对象简介 JS名言:万物皆对象 JS面向对象比PHP简单很多;因为JS中没有class关键字,...

  • JavaScript笔记(一)

    一、面向对象面向过程的区别 1、什么是js对象 js对象:属性和方法的集合,js所有数据都可以看成对象...

  • JS面向对象

    JS面向对象入门 1、面向对象语言概念面向对象语言主要包括 类、对象、封装、多肽。2、面向对象的编程思想面向过程思...

  • 2018-01-18

    js中的面向对象核心 js是基于对象的编程语言,在后面的学习中我们通过一种模式使其转化成为面向对象的语言。js面向...

  • 浅谈JS中的面向对象

    浅谈JS中的面向对象 本文主要说说本人在JS中对面向对象的理解。 计算机编程语言主要分为面向过程式编程和面向对象式...

网友评论

本文标题:js面向对象

本文链接:https://www.haomeiwen.com/subject/zqqkdxtx.html