位置: 编程技术 - 正文
推荐整理分享学习JavaScript设计模式之享元模式(javascript设计),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:javascript教程doc,javascript如何学,javascript程序设计教程,javascript课设,javascript教程chm,javascript设计,javascript设计,javascript课设,内容如对您有帮助,希望把文章链接给更多的朋友!
一、定义
享元(flyweight)模式是一种用于性能优化的模式,核心是运用共享技术来有效支持大量细刻度的对象。 在JavaScript中,浏览器特别是移动端的浏览器分配的内存并不算多,如何节省内存就成了一个非常有意义的事情。 享元模式是一种用时间换空间的优化模式
内衣工厂有种男士内衣、中女士内衣,要求给每种内衣拍照。如果不使用享元模式则需要个塑料模特;使用享元模式,只需要男女各1个模特。二、什么场景下使用享元模式?
(1)程序中使用大量的相似对象,造成很大的内存开销 (2)对象的大多数状态都可以变为外部状态,剥离外部状态之后,可以用相对较少的共享对象取代大量对象
三、如何应用享元模式?
第一种是应用在数据层上,主要是应用在内存里大量相似的对象上; 第二种是应用在DOM层上,享元可以用在中央事件管理器上用来避免给父容器里的每个子元素都附加事件句柄。
享元模式要求将对象的属性分为内部状态和外部状态。 内部状态独立于具体的场景,通常不会改变,可以被一些对象共享; 外部状态取决于具体的场景,并根据场景而变化,外部状态不能被共享。
享元模式中常出现工厂模式,Flyweight的内部状态是用来共享的,Flyweight factory负责维护一个Flyweight pool(模式池)来存放内部状态的对象。
缺点:对象数量少的情况,可能会增大系统的开销,实现的复杂度较大!
四、示例:文件上传
五、补充
(1)直接改变形参Demo
(2)对象池,也是一种性能优化方案,其跟享元模式有一些相似之处,但没有分离内部状态和外部状态的过程。
希望本文所述对大家学习javascript程序设计有所帮助。
js实现有过渡渐变效果的图片轮播相册(兼容IE,ff) 本文实例介绍了js实现图片轮播相册,具有过渡渐变效果,分享给大家供大家参考,具体内容如下思路很简单,用2个属性保存当前图片和上一张图片,
浏览器环境下JavaScript脚本加载与执行探析之动态脚本与Ajax脚本注入 在《浏览器环境下JavaScript脚本加载与执行探析之defer与async特性》中,我们研究了延迟脚本(defer)和异步脚本(async)的执行时机、浏览器支持情况、浏览器b
学习JavaScript设计模式之装饰者模式 有时我们不希望某个类天生就非常庞大,一次性包含许多职责。那么我们就可以使用装饰着模式。装饰着模式可以动态地给某个对象添加一些额外的职
标签: javascript设计
本文链接地址:https://www.jiuchutong.com/biancheng/383829.html 转载请保留说明!上一篇:纯JavaScript基于notie.js插件实现消息提示特效(javascript none)
下一篇:js实现有过渡渐变效果的图片轮播相册(兼容IE,ff)(html5过渡的触发机制)
友情链接: 武汉网站建设