ruby-on-rails – 将方法添加到Rails ActiveRecord类

ruby-on-rails – 将方法添加到Rails ActiveRecord类,第1张

概述在纯 Ruby中,这很好用: class TestSuper def foo puts "In TestSuper.foo" endendclass TestClass < TestSuper def foo super puts "In TestClass.bar" endendclass TestClass def bar put 在纯 Ruby中,这很好用:

class TestSuper  def foo    puts "In TestSuper.foo"  endendclass TestClass < TestSuper  def foo    super    puts "In TestClass.bar"  endendclass TestClass  def bar    puts "In TestClass.bar,second deFinition"    puts "Calling foo:"    foo  endendt = TestClass.newt.foot.bar

我可以在TestClass实例上调用foo()和bar()并获得我期望的结果:

In TestSuper.fooIn TestClass.barIn TestClass.bar,second deFinitionCalling foo:In TestSuper.fooIn TestClass.bar

但是,当我在Rails迁移中尝试非常类似的东西时,我会收到错误:

#### my_model.rb ####puts "In my_model.rb"class MyModel  has_many :fooend#### my_migration.rb ####puts "In my_migration.rb"class MyModel  def bar    foo.each{ |f| f.baz }  endendclass MyMigration < ActiveRecord::Migration  def self.up    MyModel.find(1).bar          end  def self.down    # Not applicable  endend

第一个问题是除非我明确地在my_migration.rb中扩展ActiveRecord,否则MyModel.find()会消失.否则,它会丢弃超类.

如果我这样做,那么我在MyModel.bar()中的foo调用上得到一个错误.

如果我在my_migration.rb中注释掉类(重新)定义,find()和bar()都可以正常工作.

在调试过程中,我添加了puts语句,以查看每个文件和时间.上课正在执行中.如果MyModel已经定义(我正在my_migration.rb中进行),似乎my_model.rb甚至都没有加载.

那么:为什么会在Rails中发生这种情况,我该如何解决呢?

解决方法 理论#2:在迁移的顶部

require 'app/models/my_model'
总结

以上是内存溢出为你收集整理的ruby-on-rails – 将方法添加到Rails ActiveRecord类全部内容,希望文章能够帮你解决ruby-on-rails – 将方法添加到Rails ActiveRecord类所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1229247.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存