- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图在上传文件并解压缩时显示进度百分比。我正在使用 ruby-zip 来解压缩该文件。解压缩时,我增加计数器并将其存储在数据库中。我有一个像
这样的表格<% form_tag '/unzip', :multipart => true do %>
<%= file_field_tag "zipfile", :size => 12 %>
<button class="add_button" type="submit" value="Add"> Add </button>
<% end %>
<div class="progress">
</div>
在unzip
操作中,有所有用于解压缩并将值存储在数据库中的操作。现在,我想每 2 秒左右更新一次 .progress div
。首先,我尝试在单击按钮时进行 ajax 调用,并调用另一个获取此进度的方法。但我没有成功,因为下面这个简单的代码给了我错误。
<script>
$(".add_button").click(function() {
$.ajax({
url: "/get_progress",
method: "POST"
})
})
</script>
在 get_progress 方法中,我只是从数据库中取出值,如
def get_progress
@progress = Progress.last.value
respond_to do |format|
format.js
end
end
为了简单的检查目的,我只是在 get_progress.js.erb
中执行 console.log("rendered")
。但这永远不会被调用,因为它之前有错误消息。但是,我检查了一下,ajax 调用正在向 get_progress
发出请求。
但问题是,我在 jquery1.6.3 第 7948 行的 xhr.send((s.hasContent && s.data) || null)
中遇到错误。我想我得到了出现此错误是因为该页面在 ajax 调用期间被重定向到其他地方,并且在我进行调用时正在进行另一个请求,因为很明显,在提交表单时我调用了另一个操作。
当我通过执行以下操作打印出 ajax 调用的错误时:
error:function(xmlHTTPRequest, textStatus, errorThrown){
console.log(xmlHTTPRequest);
}
我得到这个:
Object {readyState = 0 ,status = 0 ,statusText = "error" }
我认为我的问题与此类似question 。但是,这里提供的答案并没有解决我的问题。
有什么办法可以解决这个问题吗?我希望问题很清楚!
最佳答案
当我从 post
更改 ajax 调用时,这似乎对我有用。到 get
.
查看:
Progress:
<div id="progress">
</div>
<br />
<button class="add_button" type="submit" value="Add"> Add </button>
<script>
$(".add_button").click(function() {
$.ajax({
url: "/get_progress",
method: "get",
dataType: "script"
})
})
</script>
Controller :
def get_progress
@progress = Progress.last.value
respond_to do |format|
format.js
end
end
get_progress.js.erb:
$("#progress").text("<%= @progress.to_s %>");
一些明显的需要检查的事情:
附注要循环运行它:
function updateProgress() {
$.ajax({
url: "/get_progress",
method: "get",
dataType: "script"
});
}
// Set the function above to run every 2 seconds
var i = setInterval(updateProgress, 2000);
并更新 get_progress.js.erb:
$("#progress").text("<%= @progress.to_s %>");
var checkprogress = <%= @progress.to_i %>;
if (checkprogress == 100) {
// Stop the function running. Should add clearInterval to error handling of ajax also
clearInterval(i);
}
编辑
如果提交解压缩操作和检索进度之间存在某种冲突,我建议您使用 remotipart 使解压缩提交异步。 。然后将解压缩的形式更改为:
<% form_tag '/unzip', :html => { :multipart => true }, :remote => true do %>
并添加 create.js.erb
文件 <%= remotipart_response do %>
根据remotepart自述文件。我仍然建议 get_progress ajax 调用是 get 方法。
关于ruby-on-rails - 当后台发生其他事情时调用 ajax,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12841159/
我有一个包含两个项目的解决方案,每个项目都生成一个单独的 dll,供另一个 Windows 应用程序使用。这些项目中的每一个都有一个名为 MyActions 的类,只有一个这样的方法 项目 1
我有一个包含两个项目的解决方案,每个项目都生成一个单独的 dll,供另一个 Windows 应用程序使用。这些项目中的每一个都有一个名为 MyActions 的类,只有一个这样的方法 项目 1
所以我在 if 语句中有这段代码如下 if (!inTime || !moment(inTime).format('m') % 15 === 0) { doSomething(); } 传入的 inT
像往常一样,我想做的比我知道的还多:-D 这就是我正在做的事情......我正在写一篇简历。 但是在简介中,我想要一个“长简介”和一个“短简介”按钮。 长传记显然会显示整个传记,但短传记会捕获列表中的
我正在使用物质。 js创建一个二维场景。我在场景中对一个物体施加力,这个物体撞击其他物体,但最终所有物体都因摩擦和能量损失而停止移动。 我需要以某种方式检测场景中的所有物体何时停止移动。我发现这样
谁能快速浏览一下这段代码,让我知道哪里出错了。 在模糊事件中,.textok 类加载正常,但 .textbad 类加载不正常。 .textok { color:#0F0; background
我的情况是这样的:我有一个项目,它使用了一些生成的代码。在生成的代码中,几乎所有文件中都硬编码了某个 URI。 因此,在某些时候我得到了两个生成的代码库:一个针对开发,另一个针对暂存。 我想通过 Gr
这是一个严肃的问题(见我的评论)。 问题很简单:Java 所做的所有 SEO 不友好的事情有哪些会导致您的网站在主要搜索引擎中的排名不如应有的好? 最佳答案 有一个与 JSESSIONID 相关的 s
我正在使用 PHP。我想完成 jQuery AJAX 进程,(完成进程并数据返回主页后)。 然后执行下一个 jQuery 操作。关于如何做到这一点有什么想法吗? $.ajax({ url: "pa
在释放内存之前,我要从 CPU 缓存中逐出内存范围。理想情况下,我只想放弃这些缓存行而不将它们保存到内存中。因为没有人会使用这些值,无论谁再次获得该内存范围(在 malloc()/new/_mm_ma
我不喜欢 jackson 。 我想使用 ajax,但要使用 Google Gson。 所以我试图弄清楚如何实现我自己的 HttpMessageConverter 以将其与 @ResponseBody
我是一名优秀的程序员,十分优秀!