zoukankan      html  css  js  c++  java
  • JavaScript 原型继承

    Object.prototype

    JavaScript是基于原型继承的,任何对象都有一个prototype属性。Object.prototype是所有对象的根,并且不可改变。

    Object.prototype=null;
    alert(Object.prototype);//[object Object]

    Object与Object.prototype

    Object继承于Object.prototype,增加一个属性给Object.prototype上,同时也会反应到Object上。如:

    Object.prototype.nameStr="Object Prototype";
    Object.prototype.getName=function(){return this.nameStr};
    alert(Object.getName());//Object Prototype

    Function.prototype与Object.prototype

    由于Object.prototype是万物之根,所以Function.prototype也同时会继承Object.prototype的所有属性。如:

    Object.prototype.nameStr="Object Prototype";
    Object.prototype.getName=function(){return this.nameStr};
    alert(Function.prototype.getName());//Object Prototype

    Object/Function/String/Number/Boolean/Array与Date

    Object/Function/String/Number/Boolean/Array与Date都是函数,函数又继承于Function.prototype, 所以更改Function.prototype一样会影响到Object/Function/String/Number/Boolean/Array与Date。如:

    Function.prototype.initType='Function Type';
    Function.prototype.getType=function(){return this.initType};
    
    //alert(Object.getType());//Function Type
    //alert(Date.getType());//Function Type
    //alert(Number.getType());//Function Type
    //alert(String.getType());//Function Type
    //alert(Boolean.getType());//Function Type
    alert(Array.getType());//Function Type

    同样Function.prototype也会把所受Object.prototype的影响,传递给它的下一层级。如:

    Object.prototype.nameStr="Object Prototype";
    Object.prototype.getName=function(){return this.nameStr};
    alert(Function.prototype.getName());//Object Prototype
    alert(Array.getName());//Object Prototype
    alert(Boolean.prototype.getName());//Object Prototype

    Array/Array.prototype与Function.prototype/Object.prototype

    Array是函数对象,受Function.prototype的影响,而Array.prototype不是函数对象,所不受Function.prototype的影响,但所有对象受Object.prototype的影响,所以Array.prototype也会受Object.prototype的影响。如:

    Object.prototype.nameStr="Object Prototype";
    Object.prototype.getName=function(){return this.nameStr};
    //alert(Function.prototype.getName());//Object Prototype
    //alert(Boolean.prototype.getName());//Object Prototype
    
    Function.prototype.initFun=function(){
    	return 'Function.prototype.initFun';
    }
    
    alert(Array.initFun());//Function.prototype.initFun
    
    var arr=['a','b'];
    alert(arr.getName());//Object Prototype
    alert(arr.initFun());//Error: arr.initFun is not a function
    alert(arr.initFun);//undefined
  • 相关阅读:
    day 15 小结
    python中的数据类型以及格式化输出
    编程语言简介
    计算机简介
    堆排
    Lock锁
    JVM入门
    Java中反射调用私有方法出现NoSuchMethodException
    1248. 统计「优美子数组」
    注解
  • 原文地址:https://www.cnblogs.com/fxair/p/2302329.html
Copyright © 2011-2022 走看看