关于javascript:原型与原型链

36次阅读

共计 621 个字符,预计需要花费 2 分钟才能阅读完成。

原型与原型链

原型:prototype => 函数特有的,数组对象不具备

原型链:_ proto _ / [[prototype]] (浏览器体现形式) => 任何数据类型都有原型链

function fn (){}
fn.prototype.name = "zhangsan"
fn.prototype.fn2 = function(){log("111")}
作用:为了继承
function Person(){}
Person.prototype.name = "zhangsan"
Person.prototype.age = 18
Person.prototype.getAge = function(){console.log(this.age)
}
// new 一个实例
let person1 =  new Person()
console.log(person1.name)  // zhangsan
person1.getAge() // 18
person1.gender // not defined 
原型链的查找规定:就近准则

从以后实例去找,找到就返回,如果没找到,则顺着原型链一层一层往下来找,直到找到 null 为止(原型链顶端)还没找到,报错

通过 hasOwnProperty() 判断是公有属性还是下层的
let item;
for(item in person1){if(person1.hasOwnProperty(item)){console.log(item)
    }
}

hasOwnProperty() 办法是挂载在 Object 办法

正文完
 0