ps:用最简单的方法解释!
构造函数的创建、属性、方法
- 构造函数长这样
var Cat = function(name,color){
this name = name;
this color = color;
}
上面这个代码就是一个最基础的构造函数,需要用到
this
指向将要实例化的对象;
- 实例化
var cat1 = new Cat("金毛","黄色");
var cat2 = new Cat("小毛","红色");
这就完成了一个最基础的用构造函数实例化对象
- constructor属性
console.log(cat1.constructor == Cat);//true
console.log(cat2.constructor == Cat);//true
每一个对象都有一个
constructor属性
指向他们的构造函数
- instanceof运算符
console.log(cat1 instanceof Cat);//true
console.log(cat2 instanceof Cat);//true
instanceof运算符
验证原型对象与实例之间的关系
- prototype属性
Cat.prototype.type = '猫科动物';
构造函数
prototype属性
指向另一个对象,这个对象的所有属性和方法会被构造函数的实例对象所继承
- isPrototypeOf()方法
Cat.protorype.isPrototypeOf(cat1); //true
isPrototypeOf()
这个方法用来判断,某个proptotype对象和某个实例之间的关系
- hasOwnProperty()方法
cat1.hasOwnProperty('name'); //true
cat1.hasOwnProperty('type'); //false
每个实例对象都有一个
hasOwnProperty()方法
,用来判断某一个属性到底是本地属性,还是继承自prototype对象的属性。
- in运算符
console.log("name" in cat1); // true
console.log("type" in cat1); // true
in运算符
可以用来判断,某个实例是否含有某个属性,不管是不是本地属性。
for(var prop in cat1) {
console.log("cat1["+prop+"]="+cat1[prop]);
}
in运算符还可以用来遍历某个对象的所有属性。