JavaScript使用享元模式实现文件上传优化操作示例


Posted in Javascript onAugust 07, 2018

本文实例讲述了JavaScript使用享元模式实现文件上传优化操作。分享给大家供大家参考,具体如下:

一、享元模式是一种用于性能优化的模式,主要优化方式为,若系统中因为创建了大量类似的对象而导致内存占用过高,则可以考虑使用享元模式实现。

二、实例说明:

如果在浏览器中上传文件,若使用常规写法, 每上传一个文件,就会创建一个实例对象;如果上传2000个文件,那就有2000个对象,浏览器很可能出现假死状态。这种情况下,我们考虑适应享元模式。

三、实例:

var Upload = function( uploadType ){
  this.uploadType = uploadType;
};
Upload.prototype.delFile = function( id ){
  uploadManager.setExternalState( id, this );
  if( this.fileSize < 300 ){
   return this.dom.parentNode.removeChild( this.dom );
  }
  if( window.confirm('确定要删除该文件吗?' + this.fileName )){
     return this.dom.parentNode.removeChild( this.dom);
  }
};
var UploadFactory = (function(){
  var createdFlyWeightObjs = {};
  return {
    create: function( uploadType ){
      if(createFlyWeightObjs[uploadType]){
        return createdFlyWeightObjs[uploadType];
      }
      return createdFlyWeightObjs[uploadType] = new Upload(uploadType);
    }
  }
})();
var uploadManager = (function(){
  var uploadDatabase = {};
  return{
    add: function(id, uploadType, fileName, fileSize){
      var flyWeightObj = UploadFactory.create( uploadType );
      var dom = document.createElement( 'div' );
      dom.innerHTML = '<span>文件名称:'+fileName+',文件大小:' +fileSize + '</span>' + '<button class="delFile">删除</button>';
      dom.querySelector( ".delFile" ).onclick = function(){
       flyWeightObj.delFile( id );
       document.body.appendChild( dom );
       uploadDatabase[ id ] = {
         fileName: fileName,
         fileSize: fileSize,
         dom: dom
       };
       return flyWeightObj;
     },
     setExternalState: functon( id, flyWeightObj ){
        var uploadData = uploadDatabase[ id ];
        for( var i in uploadData){
           flyWeightObj[ i ] = uploadData[ i ];
        }
     }
  }
})();

然后需要写一个触发上传动作的startUpload函数:

var id = o;
window.startUpload = function( uploadType, files ){
  for( var i=0,file; file = fules[ i ++ ];){
     var uploadObj = uploadManger.add( ++id, uploadType, file.fileName, file.fileSize );
  }
};

最后调用,如下:

startUpload( 'plugin', [
  {
    fileName: '1.txt',
    fileSize: 1000
   },
   {
     fileName: '2.html',
     fileSize: 1000
   },
   {
     fileName: '3.txt',
     fileSize: 5000
   }
]);
startUpload( 'flash', [
  {
    fileName: '4.txt',
    fileSize: 1000
   },
   {
     fileName: '5.html',
     fileSize: 1000
   },
   {
     fileName: '6.txt',
     fileSize: 5000
   }
]);

四、解释:

调用时,有六个对象,但只有两个类型(plugin和flash),我们通过享元模式,在创建对象时,只有两个,如果上面提到的上传2000个文件,利用上面的代码,同样只创建两个对象,那么这就很好的解决了浏览器崩溃假死的问题。

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
input+select(multiple) 实现下拉框输入值
May 21 Javascript
js 自定义的联动下拉框
Feb 07 Javascript
jquery 实现二级/三级/多级联动菜单的思路及代码
Apr 08 Javascript
超简单JS二级、多级联动的简单实例
Feb 18 Javascript
深入理解Javascript里的依赖注入
Mar 19 Javascript
jquery自动填充勾选框即把勾选框打上true
Mar 24 Javascript
JS数组操作(数组增加、删除、翻转、转字符串、取索引、截取(切片)slice、剪接splice、数组合并)
May 20 Javascript
动态更新highcharts数据的实现方法
May 28 Javascript
JS获取浮动(float)元素的style.left值为空的快速解决办法
Feb 19 Javascript
vue父组件向子组件动态传值的两种方法
Nov 11 Javascript
使用Angular CLI快速创建Angular项目的一些基本概念和写法小结
Apr 22 Javascript
JS实现快递单打印功能【推荐】
Jun 21 Javascript
JavaScript设计模式之模板方法模式原理与用法示例
Aug 07 #Javascript
opencv 识别微信登录验证滑动块位置
Aug 07 #Javascript
JavaScript设计模式之缓存代理模式原理与简单用法示例
Aug 07 #Javascript
深入浅析var,let,const的异同点
Aug 07 #Javascript
springMvc 前端用json的方式向后台传递对象数组方法
Aug 07 #Javascript
JS实现中英文混合文字溢出友好截取功能
Aug 06 #Javascript
JS实现图片上传多次上传同一张不生效的处理方法
Aug 06 #Javascript
You might like
生成静态页面的php函数,php爱好者站推荐
2007/03/19 PHP
yii2.0使用Plupload实现带缩放功能的多图上传
2015/12/22 PHP
基于jquery的inputlimiter 实现字数限制功能
2010/05/30 Javascript
JavaScript中获取Radio被选中的值
2015/11/11 Javascript
最全面的JS倒计时代码
2016/09/17 Javascript
浅析Node.js:DNS模块的使用
2016/11/23 Javascript
浅谈javascript中的 “ &amp;&amp; ” 和 “ || ”
2017/02/02 Javascript
JS实现字体背景跑马灯
2020/01/06 Javascript
axios封装与传参示例详解
2020/10/18 Javascript
[02:16]DOTA2英雄基础教程 干扰者
2014/01/15 DOTA
python获取本地计算机名字的方法
2015/04/29 Python
python字典基本操作实例分析
2015/07/11 Python
学习python类方法与对象方法
2016/03/15 Python
Python 逐行分割大txt文件的方法
2017/10/10 Python
Java编程迭代地删除文件夹及其下的所有文件实例
2018/02/10 Python
python列表list保留顺序去重的实例
2018/12/14 Python
对Python中创建进程的两种方式以及进程池详解
2019/01/14 Python
学点简单的Django之第一个Django程序的实现
2021/02/24 Python
西班牙购买隐形眼镜、眼镜和太阳镜网站:Lentiamo.es
2020/06/11 全球购物
请说出你所知道的线程同步的方法
2013/04/19 面试题
化工机械应届生求职信
2013/11/04 职场文书
前台文员岗位职责
2013/12/28 职场文书
运动会广播稿60字
2014/01/15 职场文书
建筑系毕业生自我鉴定
2014/01/24 职场文书
幼儿园教师获奖感言
2014/03/11 职场文书
财产公证书格式
2014/04/10 职场文书
大学生英语演讲稿
2014/04/24 职场文书
关于保护环境的标语
2014/06/09 职场文书
计算机求职信
2014/07/02 职场文书
基层党员学习党的群众路线教育实践活动心得体会
2014/11/04 职场文书
教师党员学习群众路线心得体会
2014/11/04 职场文书
2015年国庆节慰问信
2015/03/23 职场文书
爱国主题班会教案
2015/08/14 职场文书
2019年大学生暑期社会实践调查报告模板
2019/11/07 职场文书
vue3如何优雅的实现移动端登录注册模块
2021/03/29 Vue.js
PHP中strval()函数实例用法
2021/06/07 PHP