码迷,mamicode.com
首页 > 编程语言 > 详细

基于原型继承的JavaScript对象系统

时间:2017-06-11 17:23:16      阅读:137      评论:0      收藏:0      [点我收藏+]

标签:本质   new   obj   基本   str   它的   ret   原型   基于   

原型编程范型

  基于原型链的委托机制就是原型继承的本质。

  原型编程范型的基本原则:

  1. 所有的数据都是对象。

  2. 要得到一个对象,不是通过实例化类,而是找到一个对象作为原型并克隆它。 

  function Person(name){

    this.name=name;

  }

  Person.prototype.getName=function()

  {

    return this.name=name;

  }

  var a=new Person(‘sven‘);

  console.log(a.name);//sven

  console.log(a.getName());//sven

  console.log(Object.getPrototypeOf(a)===Person.prototype);//true

  在这里Person不是类,而是函数构造器,JS的函数调用既可以作为普通函数被调用,也可以作为构造器被调用,当使用new运算符来调用函数的时,此时的函数就是一个构造器。用new运算符来创建对象的过程,实际上也只是先克隆Object.prototype对象,再进行一些其他额外操作的过程。

 

 

  3. 对象会记住它的原型。

    在js原型链查找机制中,每个对象至少应该先记住它自己的yuanx;JS给对象提供了一个名为_proto_的隐藏属性,某个对象的_proto_属性会指向它的构造器的原型对象。

 

  4.  如果对象无法响应某个请求,它会把这个请求委托给它自己的原型。

  当一个对象无法响应某条请求的时候,它会顺着原型链把请求传递下去,直到遇到一个可以处理该请求的对象为止。虽然js的对象最初都是由Object.prototype对象克隆而来的,但对象构造器的原型并不仅限于Object.prototype上,而是可以动态地指向其他对象。

  var A=function(){};
  A.prototype={name:‘sven‘};

  var B=function(){};
  B.prototype=new A();

  var b=new B();
  console.log(b.name);//sven

  

基于原型继承的JavaScript对象系统

标签:本质   new   obj   基本   str   它的   ret   原型   基于   

原文地址:http://www.cnblogs.com/aimeeyh/p/6985554.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!