新闻中心

如何用J*aScript实现一个文件上传组件_如何显示进度和处理错误?

2025-12-16
浏览次数:
返回列表
J*aScript文件上传组件需用XMLHttpRequest监听upload.onprogress获取进度,FormData封装文件,统一处理onload(200–299成功)、onerror(网络异常)和ontimeout(超时),确保上传过程透明可控。

如何用javascript实现一个文件上传组件_如何显示进度和处理错误?

用 J*aScript 实现一个带进度显示和错误处理的文件上传组件,核心在于利用 XMLHttpRequestfetch + FormData,并监听上传过程中的事件。关键不是“能不能传”,而是“传得明白、出错可知、体验可控”。

用 XMLHttpRequest 监听上传进度

XMLHttpRequest 提供了 upload.onprogress 事件,能实时获取已上传字节数和总大小,适合做进度条。

  • 创建 new XMLHttpRequest(),调用 open('POST', url)
  • 绑定 xhr.upload.onprogress = e => { if (e.lengthComputable) { ... } },其中 e.loaded 是已传字节数,e.total 是文件总大小
  • Math.round((e.loaded / e.total) * 100) 算百分比,更新 UI(比如 <progress></progress> 或自定义 div)

用 FormData 构建上传数据

前端选中文件后,用 FormData 包裹,可自动设置 Content-Type: multipart/form-data,服务端也容易解析。

  • <input type="file">files[0] 获取文件对象
  • const fd = new FormData(); fd.append('file', file);(字段名需和服务端约定一致)
  • 可额外加其他字段:fd.append('name', 'xxx');

统一处理成功、失败与网络异常

上传结果不能只靠 onload 判断,要覆盖常见错误路径:

AletheaAI AletheaAI

世界上第一个从自然语言描述中生成交互式 AI 角色的多模态 AI 系统。

AletheaAI 83 查看详情 AletheaAI
  • xhr.onload:状态码为 200–299 视为成功;否则进错误分支
  • xhr.onerror:网络中断、跨域失败、请求被阻止等
  • xhr.ontimeout:手动设 xhr.timeout = 30000,超时后触发
  • 服务端返回非 2xx 但有 JSON 错误信息?用 JSON.parse(xhr.responseText) 提取提示(注意 try-catch)

简单封装成可复用函数(示例)

把逻辑收拢,对外暴露清晰接口:

function uploadFile(file, url, onProgress, onSuccess, onError) {
  const xhr = new XMLHttpRequest();
  const fd = new FormData();
  fd.append('file', file);
<p>xhr.upload.onprogress = e => {
if (e.lengthComputable) {
const percent = Math.round((e.loaded / e.total) * 100);
onProgress?.(percent);
}
};</p><p>xhr.onload = () => {
if (xhr.status >= 200 && xhr.status < 300) {
onSuccess?.(JSON.parse(xhr.responseText));
} else {
onError?.(new Error(<code>HTTP ${xhr.status}: ${xhr.statusText}</code>));
}
};</p><p>xhr.onerror = () => onError?.(new Error('Network error'));
xhr.ontimeout = () => onError?.(new Error('Request timeout'));
xhr.timeout = 30000;</p><p>xhr.open('POST', url);
xhr.send(fd);
}

调用时只需传入文件、地址和三个回调,进度、成功、错误各司其职,不耦合 UI。

基本上就这些。不需要第三方库,原生能力足够稳;重点是别漏掉 onerror/ontimeout,不然用户卡在“转圈”却不知为何失败。

以上就是如何用J*aScript实现一个文件上传组件_如何显示进度和处理错误?的详细内容,更多请关注其它相关文章!


# java  # 澳门seo哪家好  # 论文优化网站中文  # 什麼网站利於seo优化  # url下划线 seo  # 鼓楼区网站推广代理品牌  # 威海优质的网站建设推荐  # 做一个网站怎么样优化  # 辽宁seo营销怎么样  # 自然语言  # 加密解密  # 连接数据库  # 有什么区别  # 如何使用  # 服务端  # 如何用  # 如何实现  # 文件上传  # 上传  # 状态码  # 跨域  # 字节  # app  # json  # 前端  # js  # javascript  # 广东企业网站建设销售  # 哪些网站可以推广的 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 必由学官网首页入口 必由学教师网页版登录指南  vivo手机参数配置怎么增强信号_vivo手机参数配置信号增强方法  c++中的std::basic_string的SSO优化_c++短字符串优化深度解析  steam官方入口大全 steam账号注册及操作指南  12306几点到几点不能订票? | 官方最新系统维护时间全解析  fishbowl官网免费版 fishbowl养鱼网站入口  智慧团建扫码登录入口 智慧团建扫码登录入口官网版​  俄罗斯搜索引擎Yandex指南 附2025年免登录官网入口  b站赚钱渠道_b站收益来源  微博网页版首页入口 微博电脑端官网登录链接  html两个JS只运行一个怎么办_让双JS在html中都运行方法【技巧】  Win11如何开启讲述人功能 Win11屏幕阅读器(讲述人)开启与关闭【教程】  批改网学生版PC登录 批改网官网登录系统入口  Win11怎么设置鼠标指针速度_Win11提高鼠标指针精确度选项  J*aScript数组对象转换:按指定键分组与值收集  html怎么运行外部js文件中的函数_运html外js文件函数法【技巧】  J*a实现学校排课程序_面向对象结构化项目示例  圆通快递查询实时追踪 圆通物流包裹状态快速查看  如何使 Jest 模拟函数默认抛出错误以提高测试效率  AO3访问入口汇总 AO3网页版同人作品一键直达  一加 Nord 5 隐私权限异常_一加 Nord 5 系统安全优化  QQ邮箱稳定登录入口_QQ邮箱官方网站网页版使用  优化 Jest 模拟:强制未实现函数抛出错误以提升测试效率  厨房不锈钢水槽发黑生锈怎么处理_水槽用可乐+锡纸2分钟抛亮如新  《北京人工智能产业白皮书(2025)》发布:全年核心产值预计突破 4500 亿元  邮政快递包裹最新位置 邮政快递实时追踪入口  AI抖音网页版免费视频入口 AI抖音网页端最新视频实时观看  Composer的 "check-platform-reqs" 命令有什么用_在部署前检查生产环境是否满足Composer依赖需求  CSS Grid如何控制元素对齐_align-items与justify-items组合使用  msn官网入口地址手机版 msn官方网站手机最新链接  创客贴用户入口官网登录 创客贴网页版电脑版系统  必由学官方登录入口 必由学教师学生账号快速访问  Android Studio计算器C键功能异常排查与修复教程  css子元素高度不一致导致布局错位怎么办_使用align-items:stretch解决高度差异  2026春节假期时间安排 2026春节假日查询  Win11怎么设置鼠标主按键_Win11鼠标左右键功能互换  PHP中SSG-WSG API的AES加密实践:正确使用初始化向量  QQ邮箱登录首页官网地址2026 QQ邮箱官方网页入口  豆包手机助手发布技术预览版:直接嵌入手机系统!努比亚样机发售  如何使用Rector自动化升级旧代码_通过Composer安装和配置Rector进行代码重构  J*aScript打印功能_j*ascript输出控制  夸克浏览器图书入口 夸克手机浏览器阅读入口  AO3官方在线访问地址 Archive of Our Own最新镜像合集  快手网页版在线登录 快手网页版官网入口快速访问  在命令行怎么运行html项目_命令行运行html项目方法【教程】  c++中为什么推荐使用using替代typedef_c++现代化类型别名  双系统安装时,如何设置默认启动系统? msconfig命令了解一下!  mysql通配符支持数字匹配吗_mysql通配符能否用于数字匹配的解析  Golang如何安装Swagger工具_GoSwagger文档生成环境  CSS Box Model与弹性按钮:维持布局稳定的动画实践 

搜索