function Phone(brand, color, size){
this.brand = brand;
this.color = color;
this.size = size;
this.call = function () {
console.log("打电话");
this.mail = function(){
console.log("发短信")
}
}
}
var hw = new Phone("华为", "蓝色", "5.7");
hw.call();
hw.mail()
var njy = new Phone("诺基亚", "黑色", "2.0");
njy.call();
njy.maill();
//hw.call()和njy.call()行为一样但是,地址却不一样
将上面的所有行为函数封装到一个对象中
var obj = {
call: function () {
console.log("打电话");
},
mail: function () {
console.log("发短信“);
}
}
function Student(brand, color, size) {
this.brand= brand;
this.color =color;
this.size = size;
this.call = obj.call;
this.mail = obj.mail;
}
var hw = new Phone("华为", "蓝色", "5.7");
hw.call();
hw.mail()
var njy = new Phone("诺基亚", "黑色", "2.0");
njy.call();
njy.maill();
调用hw.call()和njy.call()其实是一样的地址,优化,而每次创建对象总会挖一个对象的坑(也就是创建一个对象空间),也会占用内容,而js给我们创建了一个prototype原型属性的概念