设计模式之原型模式

原型模式

原型模式(prototype)是指原型实例指向对象的种类,并且通过拷贝这些原型创建新的对象

模式作用:

  1. 原型对象本身就是有效地利用了每个构造器创建的对象

注意事项:

  1. 注意的依然是浅拷贝和深拷贝的问题,免得出现引用问题
  2. 现有的文献里查看原型模式的定义,没有针对JavaScript的,你可能发现很多讲解的都是关于类的,但是现实情况是基于原型继承的JavaScript完全避免了类(class)的概念

例子:

//原型
var myobj={
  str:"mystring",
  num:1,
  myarr:[30,{
    arrgo:"i am arr"
  }],
  obj:{
    innerobj:{
      test:25
    },
    innerstr:"myobjInnerstr"
  }
}

浅拷贝

function clone(obj){
  var ret={};
  for(k in obj){
    ret[k]=obj[k];
  }
  return ret;
}

var result=clone(myobj);
result.obj.innerstr="outter";
console.log(result);
console.log(myobj)
//此时会发现修改了result也会导致myobj受到影响

深拷贝

function clone(obj){
  var ret,k,b;
  if((b=(obj instanceof Array))||obj instanceof Object){
    ret=b?[]:{};
    for(k in obj){
      if((obj[k] instanceof Array||obj[k] instanceof Object)){
        ret[k]=clone(obj[k]);
      }else{
        ret[k]=obj[k];
      }

    }
  }
  return ret;
}
var result=clone(myobj);
result.obj.innerstr="outter";
console.log(result);
console.log(myobj)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 前言 在 Java 中,我们可以使用 new 关键字指定类名来生成类的实例。但是,有的时候,我们也会在不指定类名的...
    Kevin_ZGJ阅读 2,675评论 0 0
  • 原型模式 有时,我们需要原原本本地为对象创建一个副本。举例来说,假设你想创建一个应用来存储、分享、编辑(比如,修改...
    英武阅读 7,116评论 1 53
  • 原型模式 定义 使用原型实例指定创建对象的种类,并且通过克隆这些原型创建新的对象。原型模式是一种对象创建型模式。 ...
    晨鸣code阅读 3,085评论 0 0
  • 月光浸满忧伤 洒落海面 最后一次凝望 沉睡中的爱人 就要失去我的爱 别了,我的爱 我静默已久不能吟唱 就让我在刀尖...
    月漫香江阅读 3,952评论 0 2
  • 智齿是指人类口腔内牙槽骨上最里面的第三颗磨牙,从正中的门牙往里数刚好是第八颗牙齿。智齿生长方面,个体有很大差异,通...
    不喜social的大给阅读 3,633评论 0 0

友情链接更多精彩内容