質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

259閲覧

Rails ActiveModel::Callbacksの呼び出しの順番について

dounatsu

総合スコア78

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2018/11/04 14:12

パーフェクトRuby on Railsで勉強中なのですが、下記コードの出力について分からないことがあります。

ruby

1class Music 2 extend ActiveModel::Callbacks 3 4 aatr_accessor :title, :created_at, :listened_at 5 6 define_model_callbacks :create 7 8 after_create ->(music){ music.created_at = Time.current} 9 10 def self.create(title: nil) 11 music = new 12 music.title = title 13 music.create 14 end 15 16 def create 17 run_callbacks :create do 18 puts "created" 19 self #ここの呼び出されるタイミング 20 end 21 end 22end

コンソール上でMusic.create(title: "test")と打ち込むと、

console

1pry(main)> Music.create(title: "test") 2created 3 4=> #<Music:0x00007ff448c09cb8 5 @created_at=Sun, 04 Nov 2018 14:04:54 UTC +00:00, 6 @title="test2">

以上の様に出力されるのですが、下記がよく分かりません。

createdと表示された後はself(オブジェクト)がreturnされているのでその中身が表示されているだけだと思うのですが、
returnした時点では、まだafter_create ->(music){ music.created_at = Time.current}は呼び出されていないはずなので、
@created_atは空のはずではないのでしょうか?

このreturnされたselfはコールバックが呼び出された後にコンソールに表示されるだけなのでしょうか。

以上よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

createdと表示された後はself(オブジェクト)がreturnされているのでその中身が表示されているだけだと思うのですが、

そのとおりですが、これはafter_create破壊的に変更されますので、最終的に外側に返り値として渡されるインスタンスには、after_createによる変更が加わったものとなっています。

投稿2018/11/07 09:25

maisumakun

総合スコア145184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

dounatsu

2018/11/09 05:59

返答遅くなり申し訳ありません。 ご回答ありがとうございました。理解いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問