草庐IT

run_callbacks

全部标签

ruby - rails 3 : Do i need to give return true in a before_save callback for an object. 保存工作?

ClassUserbefore_save:set_searchabledefset_searchableself.searchable=trueifself.status==:activeendend>>u=User.last>>u.savefalseu.save总是返回false。如果我删除before_save它会起作用另外,如果我在before_save中返回true,它也有效所以我需要在before_save中给出return语句吗?如果before_save返回false,ActiveRecord会保存一个对象吗?我在哪里可以看到有关回调及其工作流程的完整文档。提前致谢

ruby-on-rails - 是什么导致弃用警告:ActiveRecord::Base.raise_in_transactional_callbacks=?

我在运行功能规范时收到此消息:DEPRECATIONWARNING:ActiveRecord::Base.raise_in_transactional_callbacks=isdeprecated,hasnoeffectandwillberemovedwithoutreplacement.我正在使用Rails5.0.0.rc1,我不确定是什么引发了这个弃用警告。我的application.rb文件中有这个。我删除了它,弃用警告消失了:config.active_record.raise_in_transactional_callbacks=true我想了解此弃用警告的实际含义以及触发此

ruby-on-rails - 附加到 rake db :seed in rails and running it without duplicating data

Rakedb:seed使用应用程序的默认数据库值填充您的数据库,对吗?那么如果您已经有一个种子并且需要添加到它(您添加一个需要种子的新功能)怎么办?根据我的经验,当我再次运行rakedb:seed时,它已经添加了现有内容,因此现有内容变成了两倍。我需要的是添加一些种子,当运行时,它应该只添加最新的种子,而忽略现有的种子。我该怎么做?(我通常采用的肮脏的、菜鸟的方式是截断我的整个数据库然后再次运行种子,但这在生产中不是很聪明,对吧?) 最佳答案 更简洁的方法是使用find_or_create_by,如下所示:User.find_or_

ruby-on-rails - ruby rails : How to run things in the background?

当一个新资源被创建并且它需要在资源准备好之前做一些冗长的处理时,我如何将那个处理发送到后台在那里它不会阻止我的网络应用程序的当前请求或其他流量吗?在我的模型中:classUser 最佳答案 您绝对应该查看以下Railscast:http://railscasts.com/episodes/127-rake-in-backgroundhttp://railscasts.com/episodes/128-starling-and-worklinghttp://railscasts.com/episodes/129-custom-daem

ruby - Rack 并发 - rack.multithread、async.callback 或两者兼而有之?

我试图完全理解Rack中并发请求处理的选项。我已经使用async_sinatra构建了一个长轮询应用程序,现在正在使用throw:async和/或Thin的--threaded标志试验裸机Rack。我对这个主题很满意,但有些事情我就是无法理解。(不,我没有将并发误认为是并行,是的,我确实理解GIL强加的限制)。Q1。我的测试表明thin--threaded(即rack.multithread=true)在单独的线程中同时运行请求(我假设使用EM),这意味着长时间运行的请求A将不阻止请求B(IO放在一边)。这意味着我的应用程序不需要任何特殊编码(例如回调)来实现并发(再次忽略阻塞数据库调

ruby-on-rails - '需要': cannot load such file -- 'nokogiri\nokogiri' (LoadError) when running `rails server`

我正在使用DevKit在Windows8.1上运行全新安装的Ruby2.2.1。安装后我运行:geminstallrailsrailsnewtestappcdtestapprailsserver保留其他所有默认值。进程在最后一行失败,我没有运行服务器,而是收到错误消息in'require':cannotloadsuchfile--'nokogiri\nokogiri'(LoadError)每次都会发生这种情况,我环顾四周并尝试了我发现的所有方法来修复它,但到目前为止没有任何效果。这里的问题是什么?如何让一个简单的测试Rails应用程序正常工作? 最佳答案

ruby-on-rails - rails : Update model attribute without invoking callbacks

我有一个具有:credits属性的用户模型。我想要一个简单的按钮,它将通过名为“add”的路由将5添加到用户的积分中,以便/users/3/add将5添加到用户id=3的积分中。defadd@user=User.find(params[:id])@user.credits+=5redirect_toroot_pathend那是我Controller的相关部分。问题是,我不想调用@user.save,因为我有一个before_save回调,它根据当前的UTC时间重新加密用户的密码。我只想简单的给属性加5,避免回调,没想到这么简单的事情这么难。编辑:我将回调更改为:before_creat

ruby - 如何在 Ruby 中实现 "callback"?

我不确定Ruby中C风格回调的最佳惯用语——或者是否有更好的(更不像C的)。在C中,我会做类似的事情:voidDoStuff(intparameter,CallbackPtrcallback){//Dostuff...//Notifywe'redonecallback(status_code)}什么是好的Ruby等价物?本质上,当“DoStuff”中满足特定条件时,我想调用一个传入的类方法 最佳答案 不是惯用的ruby​​等价物是:defmy_callback(a,b,c,status_code)puts"didstuffwith#

ruby-on-rails - rails : around_* callbacks

我已阅读http://api.rubyonrails.org/classes/ActiveRecord/Callbacks.html上的文档,但不明白何时触发与before_*和after_*相关的around_*回调。非常感谢任何帮助。谢谢。 最佳答案 around_*回调在Action之前被调用,然后当你想调用Action本身时,你yield它,然后继续执行。这就是为什么它被称为around顺序如下:before,around,after。所以,典型的around_save看起来像这样:defaround_save#dosome

javascript - Chrome : Auto-run for Javascript code?

有人知道是否有某种方法可以为浏览器中加载的每个页面运行一段Javascript代码吗?有点像插入head里面的第一件事标签。我对Chrome的解决方案最感兴趣。也许这是Chrome扩展程序的工作? 最佳答案 查看Tampermonkey,它是一个用于运行用户脚本的Chrome扩展(相当于FF的GreaseMonkey)。要在每个页面上运行脚本,您需要在脚本开头附近有这样一行://@include*这是一个tutorial关于编写用户脚本。 关于javascript-Chrome:Auto