javascript创建对象——组合使用构造函数和原型模式

      构造函数模式用于定义实例属性,而原型模式用于定义方法和共享的属性。结果,每个实例都会有自己的一份实例属性的副本,但同时又共享方法的引用,最大限度地节约内存。另外,这种混合模式还支持向构造函数传递参数;可谓是集两种模式之长。

      function Person(name,age,job){

           this.name = name;

           this.age = age;

           this.job = job;

           this.friends = ["Shelby","Court"];

      }

      Person.protoype = {

           constructor : Person,

           sayName : function(){

               alert(this.name);

           }

     }

 

     var person1 = new Person("Nicholas",29,"Software Engineer");

     var person2 = new Person("Greg",29,"Doctor");

 

     person1.friends.push("Van");

     alert(person1.friends);    //"Shelby,Count,Van"

     alert(person2.friends);   //"Shelby,Count"

     alert(person1.friends == person2.friends);   //false

     alert(person1.sayName == person2.sayName);  //true

 

    这个例子中,实例属性都是在构造函数中定义的,而由于所有实例共享的属性 constructor 和 方法sayName() 则是在原型中定义的。而修改了person1.friends(向其中添加一个新字节字符),并不会影响到person2.friends,因为它们分别引用了不同的数组。

    这种构造函数与原型混合成的模式,是目前在ECMAScript中使用最广泛、认同度最高的一种创建自定义类型的方法。可以说,这是用来定义用类型的一种默认模式。
                 ,
              

阅读更多
个人分类: javascript 基础
上一篇Java或Web中解决所有路径问题
下一篇Ext GridPanel 的单击/双击事件
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭