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

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

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

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

jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

Q&A

解決済

1回答

1005閲覧

Railsでjqueryでajaxで更新したい

yamaoka_san

総合スコア22

Ruby on Rails 5

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

jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

0グッド

2クリップ

投稿2019/03/18 00:26

編集2019/03/18 00:51

Railsでjqueryを使ってajaxで更新したい。

初心者です。Railsでcreateし、updateはajaxでしたいのですが、上手にpostされません。

[routes.rb]

resources :temps, only: [:top, :index, :new, :create, :edit, :update]

[temp.js]

$(document).ready(function(){ $('div.index_menu_imgs').draggable(); $('div#img_00.place').droppable({ accept : 'div.index_menu_imgs:hover', drop : function(event, ui){ var place = $('div.place#img_00').attr('id'); var img_ad = ui.draggable.prop("outerHTML").replace(/"/g, "'"); var img_ad2 = $(img_ad).css("background-image"); var img_ad3 = img_ad2.replace('url(', '').replace(')', '').replace(/\"/gi, ""); alert ("ドロップ!"); $.ajax({ url:'edit', type: 'POST', data: { 'img_ad' :$('img_ad3').val(), 'place':$('place').val() }, dataType: "html" }) //成功時 .done( (data) => { console.log("成功!"); }) //失敗時 .fail((data) =>{ console.log("失敗!"); }); } }); });

[temps_controller.rb]

def edit @img = Img.find(params[:id], params[:img_ad], params[:place]) @imgs = Img.all end def update @img = Img.find(params[:id]) img.update(img_update_params) end private def img_update_params params.require(:img_ad).permit(:place).merge(user_id: current_user.id) end

ビューにはドラックアンドドロップでDBの画像を繰り返しで表示していて、指定した箇所にドロップした時点でjqueryのajaxでpostする仕組みにしたいのです。
送信する内容は、jqueryにもある通り、urlとplaceという2つの値です。

色々なサイトを参考に見様見真似で組み立ててみたのですが、

Routing Error No route matches [POST] "/temps/1/edit"

と表示されてしまいます。

トライした事:
(1)jqueryの関数を独立させてtrial.js.erbを作り、ソコにedit部分を入れて、updateとpost機能を完全に別にしてみた(違うエラーになるかなと思ったのですが、同じエラー)

(2)routes.rbを色々変更
post 'temps/:id' => 'temps#trial'
patch 'temps/:id' => 'temps#trial'
(trial.js.erbを作ってた時のルーティング。でもエラーは同じ)

(3)temps.jsのポスト先URLを色々変更
url:'/:id/edit',
url:'temps/:id/edit',
(でもエラーは同じ内容)

(4)temps.jsのデータタイプを入れたり消したり。
何も変化ナッシング。

何かとっても根本的なところで致命的な何かをしでかしているのか?全く分かっていないのか。。。
何かヒントを頂けると嬉しいです。

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

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

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

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

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

m.ts10806

2019/03/18 00:39

>初心者です と書くより質問に初心者アイコンをつけてください。
yamaoka_san

2019/03/18 00:40

すいません。初心者アイコンがどこにあるのかも分かりません。。。
m.ts10806

2019/03/18 00:48

質問投稿・編集画面のタイトル入力欄の左側ですね。
yamaoka_san

2019/03/18 00:52

できました!ありがとうございます。☺️
guest

回答1

0

ベストアンサー

No route matches [POST] "/temps/1/edit"

POSTメソッドで送信しているのでエラーになっているようです。
resourcesのeditは GET だからです。
新たにPOSTのルーティングを追加するか、GETメソッドで送信するようにしてみてください。

type: 'GET',

投稿2019/03/18 12:43

ykp_yk

総合スコア654

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

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

yamaoka_san

2019/03/18 22:38

ありがとうございます!早速トライしてみまーす
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問