构造函数是什么
function person(name,age){
this.name=name;
this.age=age;
this.profession="hoopman";
this.play=function(){
console.log("play basketball");
}
}
var person1=new person("kobe",11);
var person2=new person("james",11);
person1.name //kobe
preson2.name //james
// 实例对象与原型对象的关系
person1 instanceof person //true
// constructor指向构造函数
person1.constructor===person //true
person1.play===person2.play //false
每一次new实例化,就会创建新的profession属性和play方法,浪费内存
- prototype
每个构造函数都有prototype属性,指向另一个对象,这个对象的属性和方法,会被所有这个构造函数的实例所继承
将不变的方法和属性,定义到prototype对象上(原型对象)
function person(name,age){
this.name=name;
this.age=age;
}
person.prototype.profession="hoopman";
person.prototype.play=function(){
console.log("play basketball");
}
var person1=new person("kobe",11);
person1.play===person2.play //true
person.prototype.isPrototypeOf(person1); //true
person1.hasOwnProperty("name") //true
原文地址:https://www.jb51.cc/js/415568.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。