gpt4 book ai didi

java - 文件上传和进度条

转载 作者:行者123 更新时间:2023-11-29 09:06:58 25 4
gpt4 key购买 nike

我想在上传文件时根据读取的文件量显示进度条。

我们如何使用 JS 和 Servlet 实现这一点我知道上传我可以使用 apache commons lib 但如何根据读取的数据显示进度条。

我是否应该根据读取的数据量向 JS 代码发送大量响应,如果可以,如何实现?或者有人知道更好的选择吗?

最佳答案

我在我的应用程序中使用这段代码将进度条动态添加到表格中,我确实剪掉了一堆代码,所以可能会遗漏一些东西。您可以在 set_percantage 方法中简单地调用一个 post 到服务器。

很抱歉,如果那里仍然写着一些德语,或者如果那里有太多的一两个陈述句,那么最初这就像 400 行,填满了一张大 table 。

编辑:我通过 applet 获取信息,你可以简单地写一个 post 到你的服务器

function addDownload(filename, datPfad) { 


var table = document.getElementById("download_table");
var body = table.getElementsByTagName("tbody")[0];

var progres = function() {

var getVars = this;
this.file = filename;

this.tr = document.createElement("tr");

this.td3 = document.createElement("td");

this.progress = document.createElement('div');
this.container = document.createElement("div");
this.progressbar = document.createElement("div");
this.bar = document.createElement("div");
this.text = document.createElement("div");
this.path = datPfad;

this.progressbar.style.width = "100%";
this.progressbar.style.height = "20px";
this.text.style.fontSize = "10px";

this.bar.className = "progress";

this.progressbar.appendChild(this.bar);


this.text.style.marginTop = "-19px"
this.text.style.textAlign = "center";
this.text.style.textSize = "15px";


this.text.appendChild(document.createTextNode("Download starting"));
this.progressbar.appendChild(this.text);

this.container.appendChild(this.progressbar);

this.td3.appendChild(this.container);

this.td3.setAttribute("width", "32%");

this.tr.appendChild(this.td3);

this.tr.setAttribute("style", "background:rgb(245, 245, 245)");

this.tr.setAttribute("id",filename);

body.appendChild(this.tr);

this.set_percantage = function() {
progress = document.jsap.getProgress(getVars.file);
this.bar.style.width = progress + "%";
downloaded = document.jsap.getDownloadedSize(getVars.file);
filesize = document.jsap.getDownloadSize(getVars.file);
this.text.removeChild(this.text.firstChild);
textnode = (downloaded == 0.0 || filesize == -1.0) ? "Download starting" : downloaded + " MB of " + filesize + " MB downloaded";
this.text.appendChild(document.createTextNode(textnode));
if(downloaded >= filesize && downloaded != 0) {
row.beendet();
}


}

this.interval = window.setInterval(function() {
if(boxbuffer.innerHTML == "finished") {
window.clearInterval(this.interval);
}
row.set_percantage();
},2000);

}

我忘记了这里的 css 类:

.progress {
width:0%;
height:100%;
background: rgb(30,205,230); /* Old browsers */
/* IE9 SVG, needs conditional override of 'filter' to 'none' */
background: url();
background: -moz-linear-gradient(38deg, rgba(30,205,230,1) 0%, rgba(90,156,250,1) 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, right bottom, color-stop(0%,rgba(30,205,230,1)), color-stop(100%,rgba(90,156,250,1))); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(38deg, rgba(30,205,230,1) 0%,rgba(90,156,250,1) 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(38deg, rgba(30,205,230,1) 0%,rgba(90,156,250,1) 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(38deg, rgba(30,205,230,1) 0%,rgba(90,156,250,1) 100%); /* IE10+ */
background: linear-gradient(38deg, rgba(30,205,230,1) 0%,rgba(90,156,250,1) 100%); /* W3C */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1ecde6', endColorstr='#5a9cfa',GradientType=1 ); /* IE6-8 fallback on horizontal gradient */
z-index:2;
}

所以,我基本上做的是,我创建一个宽度为 0% 的 div 元素。xml 返回下载文件的概率。基于这个数字,我增加了 div 元素的宽度。

关于java - 文件上传和进度条,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14440281/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com