所以我在我的数据库中获取图像 url,通过 AJAX 获取数据并像这样加载图像:(已更新以显示所有步骤)
//GET urls from server
$.get("/homeBanners", null, function(data){
$.each(data, function(i, banner){
console.log(i);
generateSlide(banner, i);
});
});
//Generate a slide for loaded URL
function generateSlide(banner, index){
var li = $('<li>').attr('data-target', '#slideCarousel').attr('data-slide-to', index);
var div = $('<div>').attr('class', 'item');
if(index == 0){
li.addClass('active');
div.addClass('active')
}
li.appendTo('.carousel-indicators');
div.appendTo('.carousel-inner');
var img = $('<img />').attr('src', banner.image_url).on('load', function() {
if (!this.complete || typeof this.naturalWidth == "undefined" || this.naturalWidth == 0) {
alert('broken image!');
} else {
//div.append(img);
img.appendTo(div);
//$('#slideCarousel').before('<div id="nav"></div>').carousel().removeClass('hidden');
$('#slideCarousel').carousel().removeClass('hidden');
}
});
}
代码运行良好,图像显示良好。但在 Firefox 中,选项卡加载微调器永远不会停止。在 Chrome 中不会发生这个问题。
如果我注释附加行:
//img.appendTo(div);
或 Bootstrap Carousel 行:
> //$('#slideCarousel').before('<div id="nav">').carousel().removeClass('hidden');
微调器停止。所以我真的不知道为什么会这样。感谢您的帮助。
更新:
第一次发生在没有缓存的情况下。我正在使用 Firefox 17。
旋转木马 HTML:
<div id="slideshow">
<div class="container_12"><div id="nav"></div>
<div id="slideCarousel" class="grid_12 carousel slide hidden">
<ol class="carousel-indicators">
<!-- AJAX -->
</ol>
<!-- Carousel items -->
<div class="carousel-inner">
<!-- AJAX -->
</div>
<!-- Carousel nav -->
<a class="carousel-control left" href="#slideCarousel" data-slide="prev">‹</a>
<a class="carousel-control right" href="#slideCarousel" data-slide="next">›</a>
</div>
</div>
</div>
最佳答案
经过一些测试,似乎 .on() 事件是罪魁祸首。使用来自 this question 的已接受答案,执行以下操作:
//Generate a slide for loaded URL
function generateSlide(banner, index){
var li = $('<li>').attr('data-target', '#slideCarousel').attr('data-slide-to', index);
var div = $('<div>').attr('class', 'item');
if(index == 0){
li.addClass('active');
div.addClass('active')
}
li.appendTo('.carousel-indicators');
div.appendTo('.carousel-inner');
$('<img/>').error(function() { alert('broken image!'); })
.attr('src', banner.image_url)
.appendTo(div);
//$('#slideCarousel').before('<div id="nav"></div>').carousel().removeClass('hidden');
$('#slideCarousel').carousel().removeClass('hidden');
}
我还提供了一个显示损坏图像的演示:http://jsfiddle.net/dirtyd77/SLGdE/28/
关于javascript - 如果我异步加载图像,Firefox 选项卡加载微调器将永远运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15431798/
我希望我的UserPrice模型的属性在它们为空或不验证数值时默认为0。这些属性是tax_rate、shipping_cost和price。classCreateUserPrices8,:scale=>2t.decimal:tax_rate,:precision=>8,:scale=>2t.decimal:shipping_cost,:precision=>8,:scale=>2endendend起初,我将所有3列的:default=>0放在表格中,但我不想要这样,因为它已经填充了字段,我想使用占位符。这是我的UserPrice模型:classUserPrice回答before_val
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
这是在Ruby中设置默认值的常用方法:classQuietByDefaultdefinitialize(opts={})@verbose=opts[:verbose]endend这是一个容易落入的陷阱:classVerboseNoMatterWhatdefinitialize(opts={})@verbose=opts[:verbose]||trueendend正确的做法是:classVerboseByDefaultdefinitialize(opts={})@verbose=opts.include?(:verbose)?opts[:verbose]:trueendend编写Verb
鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
我有一个这样的哈希数组:[{:foo=>2,:date=>Sat,01Sep2014},{:foo2=>2,:date=>Sat,02Sep2014},{:foo3=>3,:date=>Sat,01Sep2014},{:foo4=>4,:date=>Sat,03Sep2014},{:foo5=>5,:date=>Sat,02Sep2014}]如果:date相同,我想合并哈希值。我对上面数组的期望是:[{:foo=>2,:foo3=>3,:date=>Sat,01Sep2014},{:foo2=>2,:foo5=>5:date=>Sat,02Sep2014},{:foo4=>4,:dat
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("
我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类
如果我使用ruby版本2.5.1和Rails版本2.3.18会怎样?我有基于rails2.3.18和ruby1.9.2p320构建的rails应用程序,我只想升级ruby的版本,而不是rails,这可能吗?我必须面对哪些挑战? 最佳答案 GitHub维护apublicfork它有针对旧Rails版本的分支,有各种变化,它们一直在运行。有一段时间,他们在较新的Ruby版本上运行较旧的Rails版本,而不是最初支持的版本,因此您可能会发现一些关于需要向后移植的有用提示。不过,他们现在已经有几年没有使用2.3了,所以充其量只能让更
我一直致力于让我们的Rails2.3.8应用程序在JRuby下正确运行。一切正常,直到我启用config.threadsafe!以实现JRuby提供的并发性。这导致lib/中的模块和类不再自动加载。使用config.threadsafe!启用:$rubyscript/runner-eproduction'pSim::Sim200Provisioner'/Users/amchale/.rvm/gems/jruby-1.5.1@web-services/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:105:in`co