1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Rails5のAjax

Posted at

Rails Guideの説明を読んでもいまいちよくわからなかったので頭の整理をするために書いておく。

  1. form_with, link_to, buttonなどでAjaxリクエストを送信
  2. コントローラーの respond_toの中にformat.jsを書くと対応するxxxx.js.erbでJavascriptコードを作成する。
users_controller.rb
def index
  @users = User.all
  respond_to do |format|
    format.js
  end
end
  1. 返されたJavascriptによって元画面の書き換えが行われる。
index.js.erb
# 実際はappendToではなくreplaceWithを使って書き換えるケースが多いと思う。
$("<%= escape_javascript(render @users) %>").appendTo("#users");

ちなみに renders @users は 対応する部分テンプレート(_user.html.erb)に受けとったデータを描画する。

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?