官术网_书友最值得收藏!

Using a simple function to create plain objects

In our first example, we created a plain myCar object out of thin air  we can simply wrap the creation code into a function, which gives us a very basic object creator:

var makeCar = function() {
  var newCar = {}; 
  newCar.honk = function() {
    console.log('honk honk');
  };
};

For the sake of brevity, the drive function has been omitted.

We can then use this function to mass-produce cars:

var makeCar = function() { 
  var newCar = {} 
  newCar.honk = function() {
    console.log('honk honk'); 
  }; 
  return newCar; 
};

myCar1 = makeCar();
myCar2 = makeCar();
myCar3 = makeCar();

One downside of this approach is efficiency: for every myCar object that is created, a new honk function is created and attached  creating 1,000 objects means that the JavaScript interpreter has to allocate memory for 1,000 functions, although they all implement the same behaviour. This results in an unnecessarily high memory footprint of the application.

Secondly, this approach deprives us of some interesting opportunities. These myCar objects don't share anything  they were built by the same creator function, but are completely independent from each other.

It's really like with real cars from a real car factory: They all look the same, but once they leave the assembly line, they are totally independent. If the manufacturer should decide that pushing the horn on already produced cars should result in a different type of honk, all cars would have to be returned to the factory and modified.

In the virtual universe of JavaScript, we are not bound to such limits. By creating objects in a more sophisticated way, we are able to magically change the behaviour of all created objects at once.

主站蜘蛛池模板: 买车| 囊谦县| 达州市| 武安市| 福建省| 广安市| 柏乡县| 尉氏县| 勐海县| 苍梧县| 托克托县| 郎溪县| 申扎县| 蒲城县| 莆田市| 新余市| 灵川县| 来宾市| 隆昌县| 呼伦贝尔市| 弥渡县| 庆阳市| 手游| 亳州市| 象州县| 桃源县| 西华县| 利川市| 辽阳市| 浠水县| 淮滨县| 内黄县| 南昌市| 灌云县| 喀喇沁旗| 邯郸县| 汕头市| 栾城县| 定边县| 枞阳县| 禄劝|