草庐IT

ruby-on-rails - Ruby on Rails - 从 View 调用 Controller 方法

抱歉,我有一个Rails新手问题。在我的Rails应用程序中,如何从View调用Controller中定义的方法?例如,假设我编写了一个检索股票信息的自定义方法。在我看来,我想要一个常规的HTML按钮,单击该按钮将调用我的自定义方法并填充库存结果。这是怎么做到的?我环顾四周,找不到一种直接的方法来做到这一点。但我确定我在这里遗漏了一些东西。 最佳答案 编辑:我根据标题回答了问题,但问题不是这个问题。您问题标题的答案在底部您想要的是一个ajax请求,它是一个单独的Controller操作。你需要:请求路由并在单击按钮时填充其DOM对象

ruby-on-rails - 你如何在 rails 中为 "Likes"建模?

我有3个模型:用户、对象、喜欢目前,我有模型:一个用户有很多对象。我如何进行建模:1)一个用户可以喜欢很多对象2)一个对象可以有很多点赞(来自不同的用户)所以我希望能够做这样的事情:User.likes=用户喜欢的对象列表Objects.liked_by=对象喜欢的用户列表下面的模型肯定是错误的...classUser:likesendclassLikes:likesend 最佳答案 为了进一步阐述我对BrandonTilley的回答的评论,我建议如下:classUser:likes,:source=>:thingendclassL

ruby-on-rails - Ruby 中的符号和变量有什​​么区别?

这个问题在这里已经有了答案:HowtounderstandsymbolsinRuby(11个答案)关闭8年前。我想了解ruby​​中符号和变量之间的区别。他们在给出一个引用对象的名称时似乎做了完全相同的事情。我已经阅读过这些符号以加快程序速度,但我不确定它们与变量有任何不同的原因或方式。

ruby-on-rails - railstutorial 调试信息来自哪里

在第7章中,我使用获得以下输出---!ruby/hash-with-ivars:ActionController::Parameterselements:controller:static_pagesaction:homeivars::@permitted:false谁能解释一下hash-with-ivars的来源以及什么是ivars::@permitted:false是什么意思? 最佳答案 有趣的问题!我在一个Rails项目的所有库资源中搜索了'hash-with-ivars'并且只出现了一个地方:psychrubylibrary

ruby-on-rails - Ruby 企业版与 Ruby 1.9

我打算建立一个简单的CMS网站,用户可以在其中提交和查看包含视频、照片和文本的帖子。我想做的一个决定是在Ruby企业版和Ruby1.9之间做出选择。我关心的事情按顺序排列:性能和可扩展性。与现有gems/插件/开源项目的兼容性。开发和部署速度(我将在VPS上部署)。你有什么建议? 最佳答案 根据我的经验,REE倾向于在奇怪的地方抛出malloc(2009年1月脚本/控制台中的选项卡完成-https://webrat.lighthouseapp.com/projects/10503/tickets/89-excessive-outpu

ruby-on-rails - 如何在我的 gem 中写入 Rails 记录器

我有一个我写的gem,我在我的Rails应用程序中使用它。我想从我的gem写入railslogger,但显然那里不存在标准railslogger。实现我想做的事情的正确方法是什么? 最佳答案 正如FrederickCheung所说,您应该为您的gem使用命名空间记录器:MyGem.logger。然后将其设置为Railtie中的Rails记录器,以便您的gem在Rails内部和外部都能很好地工作。moduleMyGemclassRailties 关于ruby-on-rails-如何在我的g

ruby-on-rails - 为什么使用 "self"访问 ActiveRecord/Rails 模型属性?

在我的整个应用程序中,self.没有必要引用用户名。name工作正常。为什么以下代码需要self才能按预期工作?classUser顺便说一句,我知道validates_presence_of可以用来防止保存,但如果没有给出名称,我想使用默认值保存。rails3.0.7。 最佳答案 通常使用self是为了强制Ruby将其识别为方法调用,而不是将其错误解释为变量。如果事先不知道名为day=的方法,那么day="x"在Ruby中看起来就像一个变量赋值。self.day="x"始终是方法调用。之所以麻烦是因为name和name=方法是在解析

ruby-on-rails - 如何将特定请求详细信息记录到 Rails 服务器日志

我通常不喜欢在不了解正在发生的事情的情况下直接询问如何做某事,但我对Rails还很陌生,我很难做到这一点。基本上,我需要在单个日志语句中为每个请求捕获以下信息(如果可能的话)日志条目日期日志录入时间HTTP方法请求的URL港口请求者IP地址请求者的用户代理引用网址HTTP响应码主机名自定义日志格式的首选方式是什么?是否可以只修改现有日志并将此信息传递给它?或者我是否需要扩展和覆盖我需要的行为?我不需要将其保存到不同的日志文件或任何其他文件中,只需在每次请求时输出到STDOUT。如有任何帮助,我们将不胜感激。谢谢! 最佳答案 我知道这

ruby-on-rails - Elasticsearch /轮胎 : How do I filter a boolean attribute?

我想过滤我类(class)的私有(private)bool值,以便它只显示非私有(private)但对我不起作用的资源。(我大大简化了代码)mappingdoindexes:private,type:"boolean"indexes:name,type:"string"endenddefself.search(params)tire.search(load:true,page:params[:page],per_page:20)doquery{stringparams[:query]}ifparams[:query].present?#SofarI'vetried...#filter:

ruby-on-rails - 如何在 Rails 应用程序中调试 resque 作业

如何在Rails应用程序中调试resque作业?我只想在self.perform函数的日志文件中写入一些信息。这是我写的system("echosos>>/home/maruf/Desktop/log.txt")在self.perform()中。但什么也没发生。什么是正确的方法? 最佳答案 为什么不使用Logger工具?log=Logger.new'log/resque.log'log.debug"foobar"然后tail-f你新生成的日志在"#{Rails.root}/log/resque.log'。记得重启你的resque工作