var obj = { name: 'mm', age: 18, sayName: function() { console.log(this.name); } }
问题:创建多个对象时会造成代码冗余,很占内存空间。
二、工厂模式//function createToy(name) { // var o = new Object(); // o.name = name; // o.say = function() { // console.log(this.name); // } // return o; //} function createToy(name) { return { name: name, say: function() { console.log(this.name); } } } var toy1 = createToy('car'); toy1.say(); var toy2 = createToy('taxi'); toy2.say(); var toy3 = createToy('bus'); toy3.say(); console.log(toy1 instanceof Object); console.log(toy2 instanceof Object); console.log(toy3 instanceof Object);
问题:虽然解决了对象字面量创造对象冗余的问题,但是存在对象识别的问题,不能反映它们之间的内在关系。
三、构造函数模式function Toy(name) { this.name = name; this.say = function() { console.log(this.name); } } var toy1 = new Toy('car'); var toy2 = new Toy('car'); console.log(toy1.constructor); console.log(toy2.constructor); console.log(toy1.say === toy2.say); // false
问题:解决了工厂模式的问题,但是相同方法重复创建就浪费了内存空间。
四、原型模式function Person() {}; Person.prototype = { constructor: Person, name: 'mm', friends: ['mike','helen'], say: function() { console.log(this.name); } } var toy1 = new Person('train'); var toy2 = new Person('bus'); toy1.friends.push('suhai'); console.log(toy1.friends); console.log(toy2.friends);
问题:共享方法,解决了构造函数的问题。但是当前实例的引用类型的属性被所有实例共享,一个变所有变。
五、组合模式(构造函数+原型模式)function Person(name) { this.name = name; this.friends = ['mike','helen']; }; Person.prototype = { constructor: Person, say: function() { console.log(this.name); } } var toy1 = new Person('train'); var toy2 = new Person('bus'); toy1.friends.push('suhai'); console.log(toy1.friends); console.log(toy2.friends);
这是常用的创建方式。
通过构造函数模式定义实例属性,通过原型模式定义方法和共享的属性。