位置: 编程技术 - 正文

NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法(h5 nodejs)

编辑:rootadmin

推荐整理分享NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法(h5 nodejs),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs与html交互,node.js与php,nodejs和html,node.js html,h5 nodejs,nodejs和html,nodejs和html,node.js与javascript,内容如对您有帮助,希望把文章链接给更多的朋友!

实现多文件拖拽上传的简易Node项目,可以在github上下载,你可以先下载下来: 运行该项目,通过app.js启动项目,如果提示找不到node.exe执行环境,请指定好你的node.exe安装位置。这里我用的express框架是3..2版本。

我们来简单介绍下拖拽效果是怎么实现的。

这里先看代码:

   html内容很简单,一个显示允许的拖拽范围,一个用来显示上传文件内容的div块。

Js部分:

这里我准备了一个EventUtil接口对象,你也可以把它看成处理事件的很小的库,它的作用是封装了各个浏览器绑定相同事件的不同方法,为了实现各浏览器通用的事件绑定方法,统一用EventUtil对象来实现,你可以简单看下它的实现代码,非常简单。

当浏览器检测到拖拽的三种事件情况,“dragenter”,“dragover”,“drag"默认的行为会被阻止,当为”drag“情况时执行我们的自定义事件。

因为我们上传的是文件,所以这里用到了FormData的实例,通过append()添加文件到该对象中成为队列文件,上传到服务器端后会按队列顺序被解析成属性对象。事件中通过”event.dataTransfer.files“来获取事件中存储的文件。

这里还有一点需要注意的是jquery的ajax方法在上传文件对象时需要配置processData为false,意指不使用默认的读取字符串的操作。原因是默认情况下,通过data选项传递进来的数据,如果是一个对象(技术上讲只要不是字符串),都会处理转化成一个查询字符串,以配合默认内容类型 "application/x-www-form-urlencoded"。如果要发送 DOM 树信息或其它不希望转换的信息,需要设置为 false。

文件上传成功后控制台会打印”{infor:"success”}“信息。

到此,前端部分结束,下面我们来看Node.js端的代码。

NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法(h5 nodejs)

文件结构如下:

我们先看路由——app.js里的内容:

  和初始的app.js有几点不同,我把app对象导出来以便在fileUpload.js中重复利用,然后引入了fileUpload.js模块,并通过该接口对象获得保存该模块所有方法的uploadTest对象并调用uploadFile方法。

好,最后我们来看fileUpload.js文件:

  nodeJs总是非常简便威猛的,而且具有高度的可创性,这也是我喜欢它的理由。我们看到这里的关键代码其实很少,我简单介绍下实现文件上传的逻辑过程:

&#;获取上传文件的文件名

&#;设置文件的存储位置,以及文件名称

&#;读取文件的内容流并创建新文件写入内容流

为了实现上传多个文件,我还做了一些匹配操作,很直观,不难理解。

文件上传成功后,会出现在public文件下的uploadFiles文件下。

文件中所用到的模块都记录在package.json中,可以通过进入package.json的同级目录地址通过指令”npm install“安装。如果是直接运行github上下载的工程文件,就不用再安装了。

以上所述是小编给大家介绍的NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

nodejs如何获取时间戳与时间差 Nodejs中获取时间戳的方法有很多种,例如:1.newDate().getTime()2.Date.now()3.process.uptime()4.process.hrtime()平时想获取一个时间戳的话,用这些方法都可以,那么这

浅析Node.js实现HTTP文件下载 前言HTTP实现文件下载时,只要在服务器设置好相关响应头,并使用二进制传输文件数据即可,而客户端(浏览器)会根据响应头接收文件数据。而在Node.js

angularJS 如何读写缓冲的方法(推荐) 写在前面1.在客户端、服务端架构中,HTTP协议是主流通信技术;2.HTTP协议的无状态特性,节省带宽,较少服务器的负载,缓冲技术具有重要的运用;这

标签: h5 nodejs

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

上一篇:Node.js如何自动审核团队的代码(nodejs自动生成接口文档)

下一篇:nodejs如何获取时间戳与时间差(node 获取当前时间)

  • 企业增值税退税是算企业利润的吗
  • 销售不动产税率9%还是5%
  • 高新企业奖励金怎么领
  • 建材公司小规模纳税人税率
  • 建筑工程劳保费返还给项目部吗
  • 发出材料汇总表金额怎么算
  • 个税扣除是扣我们的钱吗
  • 广告业与服务业哪个好
  • 转出未交增值税借方余额怎么处理
  • 开一张增值税发票需要交哪些税
  • 增值税发票开具红字发票后上月税款怎么交?
  • 税控盘锁死还能报税吗
  • 成品油消费税征税
  • 哪些情况下需要更换轮胎
  • 有限合伙企业需要承担无限连带责任吗
  • 企业可以用当月的进项票抵扣上月的销项吗?
  • 小企业会计准则会计科目表
  • 单位社保部分会扣吗
  • Google Bard VS ChatGPT:哪个是更好的AI聊天机器人?
  • 境内单位和个人将船舶出租到境外的,不征收车船税
  • schupd.exe - schupd是什么进程 有什么用
  • 往来款的意义
  • 退货 会计
  • thinkphp钩子场景
  • ajax与php交互
  • 公司未成立,发起人的责任
  • 保险补偿金额的计算
  • web前端面试常见问题
  • ElementUI中<el-form>标签中 ref、:model、:rules 的作用
  • vue插槽使用
  • 软件开发服务费税率
  • c语言 *指针
  • 印花税减半征收减免性质代码
  • 固定资产清理是什么意思
  • 买地建厂房账务处理
  • 在建工程转入固定资产后又发生了后期支出会计处理
  • 现金流量表年报期末现金余额
  • 哪些发票可以抵扣?
  • 外出经营税收缴纳
  • 维修费发票应必须开具吗
  • Linux编译mssql扩展使用php连接sqlserver2008的使用步骤
  • 汇算清缴补交的所得税怎么记帐
  • mysql@变量
  • 购销合同谁来做
  • 物业公司物业费计入什么会计科目
  • 预交的城建税及附加税
  • 自然人独资交企业所得税吗
  • 两个公司开发票
  • 进口ddp税款如何缴纳
  • 广告类的公司
  • 人民币支付结算系统CIPS
  • 股权转让的账务怎么处理 会计分录
  • 跨年的费用怎么调整
  • 差旅费一般包括往返及当地的交通费
  • 企业主要的工会是什么
  • 费用报销银行转账用途怎么写
  • 计提折旧对公司有什么好处
  • 凭证上的数字金额怎么填
  • mysql启动成功但是无法连接
  • win7任务管理器快捷键ctrl+alt+
  • win8系统故障了怎么办
  • 电脑开机后显示xp界面后一直是黑屏状态
  • linux用户账户管理
  • windows 10预览版
  • 禁用强制驱动程序签名有什么用
  • opengl cullface
  • javascript中的document.write
  • 如何用bat删除指定文件
  • js用什么编写
  • jquery手机插件
  • Shell脚本监控日志 出现关键字 grep提醒
  • jquery1.8
  • android性能测试
  • python中chr(ord())
  • 税务局收垃圾处置费
  • 汽车维修增值税专用发票
  • 补农行卡怎么补几天能补完
  • 直辖市税务局
  • 企业所得税的计算,收入是含税还是不含税
  • 18个税种已立法数量
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设