-----》 为了解决从原型对象生成实例的问题,Javascript提供了一个构造函数(Constructor)模式。
1.构造函数模式
//构造函数模式 function Cat (name,color){ this.name = name; this.color = color; } var cat1 = new Cat('大毛',"红色"); var cat2 = new Cat('二毛','黑色'); console.log(cat1.name) //大毛 console.log(cat1.constructor == Cat); //true;同时指向的Cat; console.log(cat2.constructor == Cat); //true;同时指向的Cat; //存在的问题 我们在函数内添加俩个不变的属性,每一次生成一个实例,都必须为重复的内容,占用内存; // 这样就使得每个实例同时指向原型对象 Cat.prototype.type = '猫科动物' Cat.prototype.eat = function (){ alert('吃老鼠') } // 为了配合prototype属性,Javascript定义了一些辅助方法,帮助我们使用它。 //这个方法用来判断,某个proptotype对象和某个实例之间的关系。 alert(Cat.prototype.isPrototypeOf(cat1)); //true alert(Cat.prototype.isPrototypeOf(cat2)); //true //hasOwnProperty 判断属性本地属性还是继承属性; alert(cat1.hasOwnProperty("name")); // true alert(cat1.hasOwnProperty("type")); // false // 每个实例对象都有一个hasOwnProperty()方法,用来判断某一个属性到底是本地属性,还是继承自prototype对象的属性。 alert(cat1.hasOwnProperty("name")); // true alert(cat1.hasOwnProperty("type")); // false // in运算符可以用来判断,某个实例是否含有某个属性,不管是不是本地属性。 alert("name" in cat1); // true alert("type" in cat1); // true // in运算符还可以用来遍历某个对象的所有属性。 for(var prop in cat1) { alert("cat1["+prop+"]="+cat1[prop]); }