美文网首页
JS中实现面向对象的设计模式

JS中实现面向对象的设计模式

作者: 2016_18点 | 来源:发表于2017-05-06 14:35 被阅读0次

工厂模式
用函数封装以特定接口创建对象。其实现方法非常简单,也就是在函数内创建一个对象,给对象赋予属性及方法再将对象返回即可。

function createBlog(name, url) {
  **var o = new Object();**
  o.name = name;
  o.url = url;
  o.sayUrl= function() {
    alert(this.url);
  }
  return o;
}
var blog1 = createBlog('wuyuchang', 'http://www.jb51.net/');

缺点: 工厂模式却无从识别对象的类型,因为全部都是Object


构造函数模式(方法和属性全都写在构造函数中
特点:
函数名首写字母为大写(惯例)
没有显示的创建对象
直接将属性和方法赋值给了this对象
没有return语句
使用new创建对象
能够识别对象(这正是构造函数模式胜于工厂模式的地方)

function Blog(name, url) {
  **this**.name = name;
  **this**.url = url;
  **this**.alertUrl = function() {
    alert(this.url);
  }
}
var blog = new Blog('wuyuchang', 'http://www.jb51.net/');
console.log(blog instanceof Blog); // true, 判断blog是否是Blog的实例,即解决了工厂模式中不能

缺点:每次创建实例的时候都要重新创建一次方法


原型模式方法和属性全都写在原型中

function Blog() {
}

**Blog.prototype.name** = 'wuyuchang';
**Blog.prototype.url** = 'http://tools.jb51.net/';
**Blog.prototype.friend** = ['fr1', 'fr2', 'fr3', 'fr4'];
**Blog.prototype.alertInfo** = function() {
  alert(this.name + this.url + this.friend );
}

// 以下为测试代码
var blog = new Blog(),blog2 = new Blog();
blog.alertInfo(); // wuyuchanghttp://tools.jb51.net/fr1,fr2,fr3,fr4
blog2.alertInfo(); // wuyuchanghttp://tools.jb51.net/fr1,fr2,fr3,fr4

blog.name = 'wyc1';
blog.url = 'http://***.com';
blog.friend.pop();
blog2.name = 'wyc2';
blog2.url = 'http://+++.com';
blog.alertInfo(); // wyc1http://***.comfr1,fr2,fr3
blog2.alertInfo(); // wyc2http://+++.comfr1,fr2,fr3

缺点:
1.省略了构造函数传递初始化参数这一环节,结果所有实例在默认情况下都取得了相同的属性值,这样非常不方便
2.由于共享,因此因此一个实例修改了引用,另一个也随之更改了引用。


混合模式原型模式 + 构造函数模式
混合模式中构造函数模式用于定义实例属性,而原型模式用于定义方法和共享属性。每个实例都会有自己的一份实例属性,但同时又共享着方法,最大限度的节省了内存。另外这种模式还支持传递初始参数。优点甚多。这种模式在ECMAscript中是使用最广泛、认同度最高的一种创建自定义对象的方法。

function Blog(name, url, friend) {
  **this**.name = name;
  **this**.url = url;
  **this**.friend = friend;
}

**Blog.prototype.alertInfo** = function() {
  alert(this.name + this.url + this.friend);
}

var blog = new Blog('wuyuchang', 'http://tools.jb51.net/', ['fr1', 'fr2', 'fr3']),
  blog2 = new Blog('wyc', 'http://**.com', ['a', 'b']);

blog.friend.pop();
blog.alertInfo(); // wuyuchanghttp://tools.jb51.net/fr1,fr2
blog2.alertInfo(); // wychttp://**.coma,b

动态原型模式原型写在构造函数中,通过条件判断是否初始化原型

function Blog(name, url) {
  this.name = name;
  this.url = url;

  **if** (typeof this.alertInfo != 'function') {
    // 这段代码只执行了一次
    alert('exe time');
    **Blog.prototype.alertInfo** = function() {
      alert(thia.name + this.url);
    }
  }
}
var blog = new Blog('wuyuchang', 'http://tools.jb51.net'),
  blog2 = new Blog('wyc', 'http:***.com');

相关参考:

JS面向对象基础讲解(工厂模式、构造函数模式、原型模式、混合模式、动态原型模式)

相关文章

  • JS中实现面向对象的设计模式

    工厂模式用函数封装以特定接口创建对象。其实现方法非常简单,也就是在函数内创建一个对象,给对象赋予属性及方法再将对象...

  • 实现:使用c++模拟,实现GOF的23种设计模式。 设计模式在面向对象系统的设计和开发中的作用和数据结构对于面向过...

  • 设计模式的原则

    面向对象的原则是面向对象的目标,而设计模式是为了实现这些原则的手段和方法。这也就是为什么要有设计模式。 面向对象的...

  • 2018-01-18

    js中的面向对象核心 js是基于对象的编程语言,在后面的学习中我们通过一种模式使其转化成为面向对象的语言。js面向...

  • 面向对象设计原则

    面向对象设计原则 面向对象设计原则是设计模式的基础,每个设计模式都符合一一种或多种面向对象的设计原则。 常用的面向...

  • js设计模式

    我们都知道js本身是没有设计模式这一说的。但是我们却可以通过一些js特性来实现其他需要所引以为傲的面向对象编程模式。

  • js面向对象设计模式

    1、工厂模式 2、构造函数模式 3、原型模式 4、组合使用构造函数模式和原型模式 5、动态原型模式 6、寄生构造函...

  • Golang 设计模式之-装饰模式

    Golang 设计模式之-装饰模式 最近在温习设计模式,虽然面向对象不是go的特长,但用go实现的设计模式,比ja...

  • 深入学习 JavaScript —— 面向对象思想

    前言 这一篇比较简单,就总结整理下 JS 中实现面向对象设计思想,尤其是使用类实现的方法。我们都知道,JS 的语言...

  • 单例模式

    这几天在看PHP面向对象,设计模式与实现这本书。谈谈对单例模式的理解。 单例模式:在系统中需要一个对象来存储数据,...

网友评论

      本文标题:JS中实现面向对象的设计模式

      本文链接:https://www.haomeiwen.com/subject/xogetxtx.html