资讯专栏INFORMATION COLUMN

JS创建对象模式及其对象原型链探究(二):工厂模式

smartlion / 947人阅读

摘要:工厂模式用函数来封装,以特定接口创建对象的细节。缺点不能知道对象识别的问题对象的类型不知道。复杂的工厂模式定义是将其成员对象的实列化推迟到子类中,子类可以重写父类接口方法以便创建的时候指定自己的对象类型。

工厂模式

用函数来封装,以特定接口创建对象的细节。

1.创建对象
function createPerson(name, age, job){
    var o = new Object();
    o.name = name;
    o.age = age;
    o.job = job;
    o.showName = function(){
        console.log(this.name);
    }
    return o;
}

var p1 = createPerson("Mike", 20, "student");
var p2 = createPerson("Tom", 23, "student");

// 返回都是object 无法识别对象的类型 不知道他们是哪个对象的实列
console.log(typeof p1);  // object
console.log(typeof p2);  // object
console.log(p1 instanceof Object); // true

输出如图:

函数能够根据接收的参数来构建一个包含所有信息的Person对象。

可以无数次地调用createPerson()这个函数,每次它都会返回一个包含三个属性、一个方法的对象。

工厂模式是为了解决多个类似对象声明的问题;也就是为了解决实列化对象产生重复的问题。

优点:能解决多个相似的问题。

缺点:不能知道对象识别的问题(对象的类型不知道)。

复杂的工厂模式定义是:将其成员对象的实列化推迟到子类中,子类可以重写父类接口方法以便创建的时候指定自己的对象类型。

2.观察实例对象的构成
// 观察p1对象的构成
console.log(p1);
console.log("-----分割线-----");
// 观察p1对象的构成
console.log(p2);
console.log("-----分割线-----");


// 修改p1对象的属性,并不会影响到p2对象的属性,因为他们是函数createPerson()两个独立的实例对象
p1.age = 21;
console.log(p1.age);    //21
console.log(p2.age);    //23
console.log("p1 === p2:");
console.log(p1 === p2);

输出如图:

3.观察person对象涉及到的原型链
// 对象是没有prototype属性的
console.log("p1.prototype=");
console.log(p1.prototype);
console.log("-----分割线-----");

// p1对象本质上是o对象,即由Object构造函数生成,所以其__proto__属性指向Object.prototype
console.log("p1.__proto__=");
console.log(p1.__proto__);
console.log("-----分割线-----");

// 验证
console.log("p1.__proto__ === Object.prototype:");
console.log(p1.__proto__ === Object.prototype);
console.log("-----分割线-----");

console.log("p1.__proto__ === p2.__proto__:");
console.log(p1.__proto__ === p2.__proto__);
console.log("-----分割线-----");

输出如图:

4.观察下p1.showName属性引用的函数
console.log("p1.showName.prototype=");
console.log(p1.showName.prototype);
console.log("-----分割线-----");

console.log("p1.showName.prototype.constructor=");
console.log(p1.showName.prototype.constructor);
console.log("-----分割线-----");

console.log("p1.showName.prototype.__proto__=");
console.log(p1.showName.prototype.__proto__);
console.log(p1.showName.prototype.__proto__ === Object.prototype);
console.log("-----分割线-----");

console.log("p1.showName.__proto__=");
console.log(p1.showName.__proto__);
console.log(p1.showName.__proto__ === Function.prototype);
console.log("-----分割线-----");

输出如图:

原型链图

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/78979.html

相关文章

  • JS创建对象模式及其对象原型探究(三):构造函数模式

    摘要:创建对象与工厂模式的区别没有显示地创建对象直接将方法和属性付给了对象没有语句构造函数应该始终以一个大写字母开头。创建构造函数的实例,必须使用操作符。 构造函数模式 ECMAScript中的构造函数可用来创建特定类型的对象,像Object和Array这样的原生构造函数。也可以创建自定义的构造函数,从而定义自定义对象类型的属性和方法。 1.创建对象 function Person(name...

    Martin91 评论0 收藏0
  • JS创建对象模式及其对象原型探究(一):Object模式

    摘要:对象是由构造函数创建而成的,所以它的指向原型链图对象的原型链图对象属性引用的匿名函数的原型链图 Object模式 创建一个Object实例,再为其添加属性和方法。 这是创建自定义对象最简单的方式。 1.创建对象 // 创建person对象 var person = new Object(); person.name = Mike; person.age = 20; person.jo...

    李义 评论0 收藏0
  • JS创建对象模式及其对象原型探究(五):组合使用构造函数模式原型模式

    摘要:组合使用构造函数模式和原型模式构造函数模式用于定义实例属性,原型模式用于定义方法和共享的属性。创建对象组合使用构造函数模式和原型模式指向构造函数,这里要将其恢复为指向构造函数。另外,这种混合模式,还支持向构造函数传递参数。 组合使用构造函数模式和原型模式 构造函数模式用于定义实例属性,原型模式用于定义方法和共享的属性。 创建自定义类型的最常见方式,就是组合使用构造函数模式和原型模式。 ...

    Shimmer 评论0 收藏0
  • JS创建对象模式及其对象原型探究(四):原型模式

    摘要:原型模式定义构造函数,在构造函数的原型对象中定义对象的属性和方法,并通过构造函数创建对象。,属性存在于实例对象中,属性不存在于实例对象中分割线操作符会在通过对象能够访问给定属性时返回,无论该属性是存在于实例中还是原型中。 原型模式 定义构造函数,在构造函数的原型对象中定义对象的属性和方法,并通过构造函数创建对象。 1.创建对象 function Person(){}; Person....

    ruicbAndroid 评论0 收藏0
  • js知识梳理3:创建对象模式探究

    摘要:起因构造函数对象字面量都可以用来创建单个对象,但有明显缺点使用同一个接口创建很多对象,会产生大量的重复代码。组合使用构造函数模式和原型模式创建自定义类型的最常见方式,就是组合使用构造函数模式与原型模式。 写在前面 注:这个系列是本人对js知识的一些梳理,其中不少内容来自书籍:Javascript高级程序设计第三版和JavaScript权威指南第六版,感谢它们的作者和译者。有发现什么问题...

    MrZONT 评论0 收藏0

发表评论

0条评论

smartlion

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<