JavaScript设计模式:享元模式

享元模式

  • 共享内存,节约内存空间
  • 相同的数据共享使用
  • 将数据的方法分为内部数据、内部方法和外部数据、外部方法
  • 内部状态保存在对象内部,通常不会改变,可以共享
  • 外部状态保存在对象外部,可以随场景改变,不可以共享

使用场景

  • 一个系统有大量相同或者相似的对象,造成内存的大量耗费
  • 对象的大部分状态可以外部化,可以将这些外部状态传入对象中
  • 在使用享元模式时需要维护一个存储享元对象的享元池,而这需要耗费一定的系统资源,因此,应当在需要多次重复使用享元对象时才值得使用享元模式

享元模式的实现

使用享元模式实现分页加载数据,只创建5个div,一次显示5条数据,当切换pageIndex时,根据数据的索引获取对应的数据即可,相比于每条数据使用一个元素的显示方式,享元模式显示方式减少元素的渲染,更加高效。

let flyWeight = (function () {
  let created = [];
  function create() {
    let dom = document.createElement('div');
    document.getElementById('container').appendChild(dom);
    created.push(dom);
    return dom;
  }
  return {
    getDiv() {
      if (created.length < 5) {
        return create();
      } else {
        let div = created.shift();
        created.push(div);
        return div;
      }
    }
  }
})();

// 初始化
function init(){
  for(let i = 0; i < 5; i++){
    FlyWeight.getDiv().innerHTML = i;
  }
}

// 点击下一页创建对应的数据
function getPage(){
  let page = 0,
  num = 5,
  len = 10,
  n = ++page * num % len;
  for(let i = 0; i < num; i++){
    FlyWeight.getDiv().innerHTML = i;
  }
}

优缺点

优点

  • 极大减少内存张相似或相同对象数量,节约系统资源,提高系统性能
  • 享元模式中的外部状态相对独立,且不影响内部状态

缺点

为了是对象可以共享,需要将享元模式的部分状态外部化,分离内部状态和外部状态,是程序逻辑复杂

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端御书房

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值