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

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

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

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

1回答

376閲覧

redirect_toをrenderの代わりに使いたい

begenner

総合スコア79

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

0クリップ

投稿2018/06/08 02:16

編集2018/06/11 23:25

現在Railsでアプリを作成中ですが、自作アクションを作成しバリデーションを効かせるとどうしても画面のレイアウトが崩れ、リロードをかけるとエラーが発生してしまいます。
そこでredirect_toを使いながら戻り先に値を渡せないか調べていたところ

Formに入力した値を維持したままリロードする方法

というサイトを見つけました。
新たにサンプルを作成し、updateアクションに対して試してみましたがうまくいきません(m_ m)
エラーの内容もググって見ましたが自分には理解できませんでした。
わかる方がいらっしゃれば教えていただきますようよろしくお願いいたします(m
_m)

追記

Formに入力した値を維持したままリロードする方法

参考にしていたサイトはこちらですが指摘いただいたとおり、renderを使った処理のためredirect_toでやることは現状の自分の実力ではできるものではないため、アプリ自体の構造を見直してrenderを使った処理にしていきたいと思います。
###エラー内容
When assigning attributes, you must pass a hash as an argument.

###期待する動作
editアクションで入力されたエラー値をupdateアクションでredirect_toを使いeditアクションに渡したい
###動作環境
Ruby:2.3.5
Ruby on Rails: 4.2.10
###参考サイト
Formに入力した値を維持したままリロードする方法

###前準備

rails new sample_1 rails generate scaffold user name:string rake db:create rake db:migrate

config/routes.rb

ruby

1Rails.application.routes.draw do 2 resources :users 3 root to: "users#index" 4end 5

###該当のソースコード
app/controllers/xxx_controller.rb

ruby

1class UsersController < ApplicationController 2 before_action :set_user, only: [:show, :edit, :update, :destroy] 3. 4. 5 # PATCH/PUT /users/1 6 # PATCH/PUT /users/1.json 7 def update 8 @user.update_attributes(user_params) 9 10 if @user.save 11 flash[:notice] = "更新しました!" 12 redirect_to user_path(@user.id) 13 else 14 # ここでエラーが発生しています 15 # When assigning attributes, you must pass a hash as an argument. 16 @user.attributes = params[:user] 17 flash[:notice] = "失敗しました!" 18 redirect_to edit_user_path 19 end 20 end 21. 22. 23 private 24 # Use callbacks to share common setup or constraints between actions. 25 def set_user 26 @user = User.find(params[:id]) 27 end 28 29 # Never trust parameters from the scary internet, only allow the white list through. 30 def user_params 31 params.require(:user).permit(:name) 32 end 33end

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

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

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

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

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

guest

回答1

0

ここかな?

redirect_to edit_user_path ↓ redirect_to edit_user_path(@user.id)

『追記』
参考にしたサイトを見ました。
★をつけた行、これ、renderの間違いじゃないかな?

def update @hoge = Hoge.find(params[:id]) @hoge.update_attributes(params[:hoge]) if @hoget.save flash[:notice] = "更新しました!" redirect_to 'index' else @hoge.attributes = params[:hoeg] flash[:notice] = "失敗しました!" redirect_to edit_hoge_path ←★ end end

文章中には、renderという言葉を使ってるので。

今回でいうと、@hoge = hoge.attribute(params[:hoge])の中に入力された値が格納されているので、これをrennderの前に代入しましょう。

投稿2018/06/08 12:07

編集2018/06/11 11:17
dobby618

総合スコア302

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

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

begenner

2018/06/10 04:04

私も考えましたがこれだと入力した値をもとの画面に反映させることができませんでした
dobby618

2018/06/11 11:18 編集

追記しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問