原型

原型规则

  • 所有的引用类型(数组、对象、函数),都具有对象特性,即可自由扩展属性(除了"null"除外)
var obj = {}
obj.a = 1

var arr = []
arr.a = 1

var fn = function(){};
fn.a = 1;
  • 所有的引用类型(数组、对象、函数),都有一个_proto_(隐式原型)属性,属性值是一个普通的对象
console.log(obj.__proto__);
console.log(arr.__proto__);
console.log(fn.__proto__);
  • 所有的函数,都有一个prototype属性,属性值也是一个普通的对象
console.log(fn.prototype)
  • 所有的引用类型(数组、对象、函数),__proto__属性值指向它的构造函数的"prototype"属性值
console.log(obj.__proto__ === Object.prototype) // true
  • 当试图得到一个对象的某个属性时,如果这个对象本身没有这个属性,那么会去它的__proto__(即它的构造函数的prototype)中寻找
    function Foo(name){
        this.name = name
    }
    Foo.prototype.alertName = function(){
        alert(this.name)
    }
    
    var f = new Foo('zhangSan');
    f.printName = function(){
        console.log(this.name)
    }
    
    f.printName();  // zhangSan
    f.alertName();  // 弹出zhangSan

    var item;
    for (item in f) {
        if (f.hasOwnProperty(item)) {
            console.log(item);    // name, printName           
        }
    }

  

原文地址:https://www.cnblogs.com/Xmforever/p/10344036.html