码迷,mamicode.com
首页 > 编程语言 > 详细

Javascript 中创建自定义对象的方法(设计模式)

时间:2014-12-02 22:24:12      阅读:313      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   ar   color   使用   sp   java   on   

Javascript 中创建对象,可以有很多种方法。

Object构造函数/对象字面量:

抛开设计模式不谈,使用最基本的方法,就是先调用Object构造函数创建一个对象,然后给对象添加属性.

1     var student = new Object();
2     student.name = "xiao ming";
3     student.age = 20;
4     student.getName = function () {
5         alert(this.name);
6     }

熟悉javascript 对象字面量的同学,可以换一种更好的写法,至少看上去更简洁。

1     var student = {
2         name: "xiao hong",
3         age: 18,
4         getName: function () {
5             alert(this.name);
6         }
7     };

 缺点:上面方法有个缺点就是,使用同一个接口创建很多类似的对象时,会产生大量重复的代码。这个应该很容易理解了,函数(方法或者类)一般是用来创建公共的方法,上面的对象创建过程,根本没有函数的影子,所以谈不上什么重用。

工厂模式:

工厂模式 抽象了具体创建对象的过程。就像一个黑盒,你只要调用函数(进入工厂),并且传入相应参数(各种原材料),就会出来一个相应的对象(工厂生产的产品)。工厂模式解决了创建多个相似对象的问题。

 1     function studentFactory(name,age) {
 2         var student = new Object();
 3         student.name = name;
 4         student.age = age;
 5         student.sayName = function () {
 6             alert(this.name);
 7         }
 8         return student;
 9     }
10     var p1 = studentFactory("ming", 20);
11     var p2 = studentFactory("hong", 18);

缺点:工厂模式也有缺点,最大的缺点就是 对象类型识别的问题。只能判断出对象是Object 类型(p1 instanceof Object),而无法具体判断出来是哪种类型。使用工厂模式创建出来的student 其实都有着类似的属性和方法,只是值不同而已。这时 更好的解决方法是,创建一个Student 函数,这样所有的对象都属于 Student 类型。所以工厂模式不是不好,只是 构造函数模式更优。

自定义类型的构造函数:

构造函数可以用来创建特定类型的对象。

 1     function Student(name,age) {
 2         this.name = name;
 3         this.age = age;
 4         this.sayName = function () {
 5             alert(this.name);
 6         }
 7     }
 8     var p3 = new Student("ming", 20);
 9     var p4 = new Student("hong", 18);
10     alert(p3 instanceof Student); 
    alert(p3.sayName==p4.sayName); //false

缺点:自定义构造函数 的不足之处就是,每个对象都会重新创建自己的方法,其实这些方法功能是一样的(像 sayName),但是它们却不相同(p3.sayName 和p4.sayName不相等)。

原型模式:

定义一个空函数,然后把所有属性和方法都添加到原型上,这样所有的 对象都会共用这些属性和方法。

1     function Student() {};
2     Student.prototype.name = "ming";
3     Student.prototype.age = 20;
4     Student.prototype.friends = [‘qi‘];
5     Student.prototype.sayName = function () {
6         alert(this.name);
7     };

缺点:有些属性不能共享,共享回来带来问题,例如:friends。每位同学的friends 大多都不会相同。

构造函数与原型的组合:

 1     function Student(name, age, friends) {
 2         this.name = name;
 3         this.age = age;
 4         this.friends = friends;
 5     }
 6     Student.prototype = {
 7         constructor: Student,
 8         sayName: function () {
 9             alert(this.name);
10         }
11     };

总结:构造函数与原型的组合 是一种获得广泛认可的创建自定义类型的方法。 也是上面这些方法中的最优方法。

 

Javascript 中创建自定义对象的方法(设计模式)

标签:style   blog   io   ar   color   使用   sp   java   on   

原文地址:http://www.cnblogs.com/qiwubg/p/4138382.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!