cwninjaの答えは、トリックを行う必要がありますが、少しそれがあります。
まず、基本属性の処理はwrite_attributeメソッドで行われるため、これをタップする必要があります。
また、Railsにはコールバック構造が組み込まれていますが、邪魔にならない引数を渡すことはできませんが、タップするのがいいかもしれません。あなたはこのようにそれを行うことができますカスタムコールバックを使用して
:あなたは(あなたが複数のコールバックおよび/またはサブクラスを持っている可能性がある場合に特に便利)Railsのコールバックを使用しようと思った場合は
class Person < ActiveRecord::Base
def write_attribute(attr_name, value)
attribute_changed(attr_name, read_attribute(attr_name), value)
super
end
private
def attribute_changed(attr, old_val, new_val)
logger.info "Attribute Changed: #{attr} from #{old_val} to #{new_val}"
end
end
をあなたはこのような何かを行うことができます:
class Person < ActiveRecord::Base
define_callbacks :attribute_changed
attribute_changed :notify_of_attribute_change
def write_attribute(attr_name, value)
returning(super) do
@last_changed_attr = attr_name
run_callbacks(:attribute_changed)
end
end
private
def notify_of_attribute_change
attr = @last_changed_attr
old_val, new_val = send("#{attr}_change")
logger.info "Attribute Changed: #{attr} from #{old_val} to #{new_val}"
end
end
ピーター、それは美しいです、私は "write_attribute"のトンを節約しようとしている私はすべてのコードを散らしている。ありがとう! – BushyMark
これはRails 2専用です。 – lulalala
日付を確認せずにgoogle経由でこれに来ました。この最近のウォークスルーは、私が必要としていたことを行いました。[after_callbacksでモデルの変更を追跡する方法](http://ruby-journal.com/how-to-track-changes-with-after-callbacks-in- rails-3-or-newer /) – Jay