如果Kaminari生成返回首页的链接,则它的URL生成会忽略页面参数。但是,如果省略page参数,则应用程序会选择随机页面。因此,Kaminari的默认行为会阻止以可靠的方式分页回到第一页。我已经解决了这个问题,稍后会在下面发布我的解决方案,但我想为后代发布这个问题,而且我也是Rails的新手,因此我不确定我的解决方案是最好的或最优雅的,我对改进和改进很感兴趣,如果只是为了我自己的自私教化! 最佳答案 Kaminari中实现我们想要改变的行为的代码行在lib/kaminari/helpers/tags.rb中。,在方法Kamina
有时我希望一个变量始终是一个数组,无论它是一个标量还是已经是一个数组。所以我通常这样做:[variable].flatten与ruby-1.8.5、1.8.7、1.9.x兼容。当variable是一个字符串(variable="asdf")时,使用此方法,它会给出["asdf"]。如果它已经是一个数组(variable=["asdf","bvcx"]),它会给我:["asdf","bvcx"]。谁有更好的办法?“更好”意味着更易读、更高效、更简洁或在其他方面更有效。 最佳答案 Array(variable)应该可以解决问题。它使
我正在构建一个爬虫,我知道如何使用rubymechanize使用以下代码从网上读取页面:require'mechanize'agent=Mechanize.newagent.get"http://google.com"但是我可以使用Mechanize从文件系统中读取HTML文件吗?怎么办? 最佳答案 仅使用file://协议(protocol)对我来说效果很好:html_dir=File.dirname(__FILE__)page=agent.get("file:///#{html_dir}/example-file.html"
如果我有以下Sinatra代码:get'/hi'doerb:helloend如果我有一个名为views/hello.erb的文件,这会很好用。但是,如果我有一个名为views/hello.html.erb的文件,Sinatra找不到该文件并给我一个错误。我如何告诉Sinatra我希望它查找.html.erb作为有效的.erb扩展名? 最佳答案 Sinatra使用Tilt呈现其模板,并将扩展与其相关联。您所要做的就是告诉Tilt它应该使用ERB来呈现该扩展:Tilt.registerTilt::ERBTemplate,'html.er
在Ruby中很容易告诉循环转到下一个项目(1..10).eachdo|a|nextifa.even?putsaend结果=>13579但是如果我需要从循环外调用next(例如:方法)怎么办defmy_complex_method(item)nextifitem.even?#thiswillobviouslyfailend(1..10).eachdo|a|my_complex_method(a)putsaend我找到并有效的唯一解决方案是使用throw&catch就像在SO问题HowtobreakoutercycleinRuby?中一样defmy_complex_method(item)
使用Faraday时gem为这样的图像点击URL:http_conn=Faraday.newdo|builder|builder.adapterFaraday.default_adapterendresponse=http_conn.get'http://example.tld/image.png'如何将法拉第响应的图像文件写入磁盘?调试response.body属性显示它是二进制数据。非常感谢任何帮助。 最佳答案 为什么不像其他文件一样编写response.body?File.open('image.png','wb'){|fp|
我需要在应用程序中的所有路由上强制使用SSL,landing#index除外。在config/application.rb中,我有:config.force_ssl=true然后在landing_controller.rb中,我有:force_ssl:except=>:index但是,所有路由仍在重定向到https。有谁知道如何在Rails3.1+应用程序中有条件地强制使用SSL?解决方案:将以下内容添加到您的Gemfile:gem'rack-ssl-enforcer'将以下内容添加到您的config/application.rb:config.middleware.useRack::
我试过使用Sanitizegem清理包含网站HTML的字符串。它只删除了标记,而不是脚本标记内的JavaScript。我可以使用什么从页面中删除JavaScript? 最佳答案 require'open-uri'#includedwithRuby;onlyneededtoloadHTMLfromaURLrequire'nokogiri'#geminstallnokogirireadmoreathttp://nokogiri.orghtml=open('http://stackoverflow.com')#GettheHTMLsour
谁能帮帮我在我开始下载之前获取文件大小显示已经下载了多少%.require'net/http'require'uri'url="http://www.onalllevels.com/2009-12-02TheYangShow_Squidoo_Part1.flv"url_base=url.split('/')[2]url_path='/'+url.split('/')[3..-1].join('/')Net::HTTP.start(url_base)do|http|resp=http.get(URI.escape(url_path))open("test.file","wb")do|fi
假设我的HTML文档是这样的:NewsSomeinterestingnewshereSportsBaseballisfun!我可以使用以下代码获取标题div:require'rubygems'require'nokogiri'require'open-uri'url="mypage.html"doc=Nokogiri::HTML(open(url))doc.css(".headline").eachdo|item|putsitem.textend但我如何访问以下p标签中的内容,以便News与Someinterestingnewshere等相关? 最佳答案