位置: 编程技术 - 正文

Node.js实现兼容IE789的文件上传进度条(nodejs edge)

编辑:rootadmin

推荐整理分享Node.js实现兼容IE789的文件上传进度条(nodejs edge),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node.js server-side,node.js运行js,node.js支持win7,node.js server-side,nodejs只支持http,node.js支持win7,node.js web,node.js支持win7,内容如对您有帮助,希望把文章链接给更多的朋友!

Nodejs对文件上传的处理

在Express4里req.files已经是undefined了;现在用的最多的可能就是formidable了,你知道了它有个progress事件,于是心中大喜,低版本IE的进度条有戏了;OK,试一下:

是的,你很高兴的看到了,控制台按照预期打印了一串进度值;那么,再进一步;

call方法即在页面上显示进度值;很不幸,你只能看到最后的%,看不到上传具体详细的进度值;再探...

接下来换个思路,试一下,将进度值保存到session里,额外加一个请求来轮询这个进度值,哎哟,不错哦!为了保证你请求的进度值是你这次上传的进度值而不是其他上传的进度值,需要在上传的请求里和额外的请求里约定一个token值;现在又来一个问题就是怎么在请求的时候得到这个token,由于文件上传的请求体在Request Payload里,所以req.body拿不到带过去的值,我也不想去解析这堆了,当然我也解析不了;放在url里最好,问题在于有时候得刷新两次来刷新token,不好!不得已,我还是放在cookie里吧!

Node.js实现兼容IE789的文件上传进度条(nodejs edge)

为了IE,我来轮询进度值了,原谅我,其实我的心很痛;

call方法即在页面上显示进度值;很不幸,你只能看到最后的%,看不到上传具体详细的进度值;再探...

好吧,我又一次沦陷了;不过还是感觉不对劲,ajax轮询没有问题,问题在于session里要等到上传完毕才有值,所以只能看到%,看不到详细进度值;我是否可以认为,在progress里,之前的res.write和这次的req.session被挂起了呢,但是它又保存了每次的执行结果,直到progress完再释放,所以只能看到%;没心情看formidable的源码,当然我也看不咋懂,我就先这么认为吧!

既然ajax轮询没问题,那么就是保存到session不得劲了;实在不成,放到global里试试吧,总不会往全局对象里塞个值也会挂起吧;稍作改动放到global里:

继续轮询。

漂亮,完全就是那么回事!在chrome里看到的和HTML5的进度一个效果,只是在IE里会有点卡顿的感觉,不过还是能看到详细的进度值的;毕竟老浏览器身子骨不咋地,你们懂的;还有,每次上传都往global里塞值,怎么也得适当的清理一下吧,文件上传完毕,转移到指定目录后global['file'+queryToken]=null;

然而,轮询,就是一个接一个好多好多的请求,这里也许会出问题;要不限制一下吧,间隔ms请求一次进度值;恩,IE进度条就这么解决了,说好的丢掉flash;虽然这个轮询可以兼容所有浏览器,但毕竟要浪费那么多请求,还是判断下,在IE以外继续HTML5吧!

其实衡量一下,额外加个flash上传和额外的请求,哪个更值呢,原谅我不懂flash,就不多说了,反正我很不喜欢在页面上加一下额外的文件;

总结

关于文件上传的组件,还有很多的细节处理,本想弄一个JS文件的,后来一想,为了可复用性更强,还是作为一个独立的页面搞比较好,需要上传的地方,iframe一下就行了,肯定比弄一个JS文件要好很多。

标签: nodejs edge

本文链接地址:https://www.jiuchutong.com/biancheng/370791.html 转载请保留说明!

上一篇:解决node.js安装包失败的几种方法(node js安装教程)

下一篇:nodeJs内存泄漏问题详解(node 内存泄漏)

  • 中级财务管理与注会财务管理
  • 保证人不承担责任(胜诉案例)
  • 红冲以前年度收入成本的账务处理
  • 应收账款的账龄在年报的哪里
  • 预付账款和应付账款的区别
  • 开房屋租金发票需要带什么资料
  • 非正常损失进项税额转出会计分录
  • 永续盘存制的含义
  • 已发货未收款怎么做会计分录
  • 用人单位必须要有试用期吗
  • 长期待摊费用属于无形资产吗
  • 业务招待费如何调增调减
  • 预收物业费如何填报申报表
  • 广告业与服务业哪个好
  • 已经入账的发票能把原始票据退回吗
  • 关于行邮税四档调三档
  • 三板市场前世今生
  • 房地产开发企业什么意思
  • 宿舍管理制度规定心得体会范文
  • 企业白条报销和采取措施
  • 科目余额表借贷方余额不一致
  • 核定征收个体户怎么报税
  • 什么是进项税和销项税
  • 银行对公账户收款码
  • 境外汇款所得税缴纳规定
  • wordpress调试模式
  • 弥补以前年度亏损金额从哪里来的
  • 存放同业属于什么会计制度
  • 表单建模
  • php 性能优化
  • 社保和公积金个人缴纳在哪里查看
  • java多线程线程数控制在多少
  • metareg命令
  • 如何在织梦中设置图片加文字
  • 一个小柜的货代费用
  • 固定资产多少可以一次摊销
  • 应收利息可以计入其他应收款吗
  • 建筑企业增值税税率是多少
  • 如何查询去年企业所得税
  • 通过点击一个按键的游戏
  • 固定资产折旧的账务处理
  • 出口货物退运已补税(未退税)证明
  • 小规模纳税人收普票和专票有什么区别
  • 车间管理人员的福利费计入什么科目
  • 电脑配件入账
  • 投资有哪些方面
  • 更正申报所得税汇算清缴
  • 佣金付给别人公司合法吗
  • 会计月末都需要做什么
  • 开销项负数的流程
  • 销售部购买电脑一台分录
  • 商业折扣的会计分录
  • sql平均数函数
  • win8怎么自动修复
  • linux获取操作系统版本
  • xp 跳过 chkdsk
  • vmstat命令
  • centos6.10安装教程详解
  • Stacmon.exe - Stacmon是什么进程 有何作用
  • centos怎么安装
  • linux怎么分盘
  • .sfx.exe是什么文件
  • win10系统出现蓝色框框
  • pavfires.exe - pavfires是什么进程 有什么用
  • javascript基于什么的语言
  • 如何删掉win7系统
  • css一般可以放在几个地方
  • 简述matlab中控制系统的数学描述类型
  • shell 读取文件中的每一行并存储到数组
  • javascript中对象的含义
  • dom操作的方法有哪些
  • 如何用jquery
  • python修改图片背景
  • android缓存机制
  • 小规模纳税人房土两税优惠政策
  • 主管税务机构
  • 江苏省镇江市街道名称
  • 我国现行税率分
  • 城镇土地使用税会计分录
  • 发票清单盖章样本图片
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设