jquery ajax xhr监听上传进度显示不准确,求解
如果你是用这种方式上传的话,确实没有好方法。
因为 XMLHttpRequest.onProgress 事件能拿到的是网络传输的字节而已;你说的问题里,“上传进度已完成”,实际是指浏览器已经把文件传输给了服务端;“很久才可以”,是你服务端额外处理的时间,这段时间对浏览器来说是不可感知的,它怎么会知道你服务端处理需要多久呢? 一般处理思路有这么几种:1、上传进度设置一个最大值,比如 99%,只有当服务端真正返回结果时才会变到 100%,这种方法最为简单粗暴;
2、尽量减少服务端处理的时间,例如收到文件后交给异步队列去处理,立刻返回给客户端响应,这种方法需要额外做的事件比较多,开发难度更高一些;
3、客户端分片上传,把大文件变成若干段小“文件”,缺点是浏览器只有支持 HTML5 才支持 FormData 分片。
怎样用JS控制文件上传时FILE控件内默认的文件类型
有两种方式,1、用fileupload控件在后台判断FileUpload1.FileContent.Length判断大小,System.IO.Path.GetExtension(FileUpload1.FileName)获取文件后缀2、用jquery上传控件,可以直接判断类型和大小另外js也可以在前台判断文件类型,但不能获取文件大小,需要引用插件
如何实现上传文件带进度条
chrome可以的,IE8 IE9不知道。新版本的ajax可以做到获取上传进度
jQuery Upload Progress and AJAX file upload
简单的例子是