//本地上传图片、语音
function rsc_UploadFile(file) {
var mypic = file.files[];
//创建一个FormData空对象,然后使用append方法添加key/value
var fd = new FormData();
fd.append("myhead", mypic);
//上传图片
if (resourceManager.currentRscType==)
fd.append("action", "uploadImg");
//上传语音
else if (resourceManager.currentRscType==)
fd.append("action", "uploadVic");
//上传视频
else if (resourceManager.currentRscType == )
fd.append("action", "uploadVdo");
if (resourceManager.currentRscType == || resourceManager.currentRscType == )
$("#resourceManagerUploadContent").css("height", "330px");
else if (resourceManager.currentRscType == )
$("#resourceManagerUploadContent").css("height", "420px");
$("#upRscProcessBar").css("display","block"); $("#upSelectFileBtn").attr("disabled", "disabled"); var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function () {
if (xhr.readyState == && xhr.status == ) {
var data = JSON.parse(xhr.responseText);//如果上传图片成功,则保存
if (data.returnValue == ) { var url = '';
var sData = ''; //上传图片
if (resourceManager.currentRscType == ) {
url = GetHost() + data.returnData.tmpImgUrl;
sData = Base.encode('{"action":"saveImg","iu":"' + url + '"}');
}//上传语音
else if (resourceManager.currentRscType == ) {
url = GetHost() + data.returnData.vicUrl;
var duration = data.returnData.duration;
sData = Base.encode('{"action":"saveVic","vu":"' + url + '","dt":"' + duration + '"}');
} else if (resourceManager.currentRscType == ) {
url = GetHost() + data.returnData.vdoUrl;
var duration = data.returnData.duration;
var frontCover = GetHost() + data.returnData.tmpImgUrl;
var sData = Base.encode('{"action":"saveVdo","vu":"' + url + '","fc":"' + frontCover + '","dt":"' + duration + '"}');
}

$.ajax({
type: 'POST',
url: GetHost() + 'tyadmin/Resource/index.ashx',
data: sData,
dataType: 'json',
contentType: 'application/json',
success: function (data) {
if (data) {
if (data.returnValue == ) {
//自动点击当前选中的资源组并加载图片
if (group && group > && resourceManager.groups && resourceManager.groups.length > ) {
try {
resourceManager.isLocalUpload = true;
$("#resourceGroup_" + group).click();
} catch (e) { console.log(e); }
} //关闭图片上传窗体
closeUploadWin();
} else alert(data.returnMsg);
} else {
if (resourceManager.currentRscType == )
alert("图片上传失败,请重试!");
else if (resourceManager.currentRscType == )
alert("语音上传失败,请重试!");
else if (resourceManager.currentRscType == )
alert("视频上传失败,请重试!");
}
$("#rscUpload").val("");
},
error: function (msg) {
alert(msg.responseText);
}
}); } else alert(data.returnMsg); $("#upSelectFileBtn").removeAttr("disabled");
}
} //侦查当前附件上传情况
xhr.upload.onprogress = function (evt) { //侦查附件上传情况
//通过事件对象侦查
//该匿名函数表达式大概0.1秒执行一次 var loaded = evt.loaded;//已经上传大小情况
var tot = evt.total;//附件总大小
var per = Math.floor( * loaded / tot); //已经上传的百分比
try {
//如果点击 返回 按钮,则中断文件的传输
if (_isRSCXMLHttpAbort) {
xhr.abort();
} //百分比
var txtProgress = $("#txtProgress");
txtProgress.html(per + "%");
//进度条
$(".upRscProcessContent").css("width", per + "%");
} catch (e) { }
} xhr.open("post", GetHost() + 'tyadmin/Resource/index.ashx');
xhr.send(fd);
}

效果图如下:

js上传文件(可自定义进度条)的更多相关文章

  1. HTML5 jQuery+FormData 异步上传文件,带进度条

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <link href ...

  2. Spring Boot上传文件(带进度条)

    Spring Boot 上传文件(带进度条)# 配置文件 spring: freemarker: template-loader-path: classpath:/static/ ##Spring B ...

  3. ajax 上传文件,显示进度条,进度条100%,进度条隐藏,出现卡顿就隐藏进度条,显示正在加载,再显示上传完成

    <form id="uploadForm" method="post" enctype="multipart/form-data"&g ...

  4. MVC上传文件并模拟进度条

    进度条样式和JS <style type="text/css"> .spa { font-size: 12px; color: #0066ff; } .put { fo ...

  5. jquery ajax php 无刷新上传文件 带 遮罩 进度条 效果的哟

    在很多项目中都会叫用户上传东西这些的,自从接触了jquery 和ajax之后就不管做什么,首先都会想到这个,我这个人呢?是比较重视客户体验的,这次我这边负责的是后台板块,然后就有一块是要求用户上传照片 ...

  6. spring mvc + xmlHttpRequest2.0 实现无刷新上传文件,带进度条和剩余时间

    1.springmvc支持文件上传,需要在spring-mvc.xml配置文件中加上下面的一段话: <!-- 支持上传文件 --> <bean id="multipartR ...

  7. js实现图片上传预览及进度条

    原文js实现图片上传预览及进度条 最近在做图片上传的时候,由于产品设计的比较fashion,上网找了比较久还没有现成的,因此自己做了一个,实现的功能如下: 1:去除浏览器<input type= ...

  8. egg.js 通过 form 和 ajax 两种方式上传文件并自定义目录和文件名

    egg.js 通过 form 和 ajax 两种方式上传文件并自定义目录和文件名 评论:10 · 阅读:8437· 喜欢:0 一.需求 二.CSRF 校验 三.通过 form 表单上传文件 四.通过 ...

  9. 使用ajaxfileupload.js上传文件

    一直以来上传文件都是使用form表单上传文件,也看到过有人使用js上传文件,不过看起来蛮简单的也就没有怎么去理会.今天突然要使用这种方式上传文件,期间还遇到点问题.因此就记录下来,方便以后遇到这样的问 ...

随机推荐

  1. Codeforces 994 C - Two Squares

    C - Two Squares 思路: 点积叉积应用 代码: #include<bits/stdc++.h> using namespace std; #define fi first # ...

  2. Python pickle使用

    2019-01-15 10:04:32 用于序列化的两个模块 json:用于字符串和Python数据类型间进行转换 pickle: 用于python特有的类型和python的数据类型间进行转换 jso ...

  3. (转)C# 的 String.CompareTo、 Equals和==的比较

    String.CompareTo 语法 public int CompareTo(    string strB) 返回值 小于 0,实例小于参数 strB: 0,实例等于参数 strB: 大于 0, ...

  4. maven 把本地jar包打进本地仓库

    maven 把本地jar包打进本地仓库 1.本地有自己写的项目jar包,但是需要用maven依赖对其进行引用: 2.某个jar包在远程仓库没有,导致pom.xml报错,此时可以从网上单独下载此jar包 ...

  5. win下使用VM虚拟机安装Linux系统

    自己电脑上还是有个自己的虚拟机比较方便,之前用的Ubuntu,发现卡得不行. 现在装了个轻量级的Lubuntu,速度提升了不少. 1.下载Lubuntu,安装. 2.进入,设置root密码,初始化ro ...

  6. mybatis ----> 各种方式使用MBG

    1.maven方式使用 配置好.pom文件 ①src/main/resources下创建 generatorConfig.xml,并配置好(自动生成的配置文件骨架) ②src/main/java 下创 ...

  7. Python3之JSON数据解析实例:新闻头条 --Python3

    一.接口相关 数据服务商:聚合数据(https://www.juhe.cn/) API部分文档: 完整API文档下载:https://files.cnblogs.com/files/qikeyishu ...

  8. 发布web站点数据库环境的问题

    今天在公司部署web站点的时候发现了一个比较低级的错误,公司映射的外网的IP我们内部人员是无法进行访问的,结果我把站点配置文件中的IP改成是外网的IP,站点一直无法访问到数据.后面发现问题是,当外网用 ...

  9. 【洛谷p1507】NASA的食物计划

    (一次a……) NASA的食物计划[传送门] 好的上算法标签: 嗯这是个二维背包 (万年不变分隔线) 二维的题就是在一维基础上增加了一个条件,这个背包不仅含有质量还有体积.所以我们增加一层循环.核心算 ...

  10. 关于react16.4——高阶组件(HOC)

    高阶组件是react中用于重用组件逻辑的高级技术.可以说是一种模式.具体来说呢,高阶组件是一个函数,它接收一个组件并返回一个新的组件. 就像这样, const EnhancedComponent = ...